package news;
import java.sql.*;
public class NewsDAO
{
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
String url="jdbc:mysql://localhost:3306/joke?user=root";
public NewsDAO()
{
try {
Class.forName ("com.mysql.jdbc.Driver");
}
catch (java.lang.ClassNotFoundException e) {
System.err.println("joke():"+e.getMessage());
}
}
public News getNewsByPrimaryKey(int newsid) throws SQLException
{
Connection conn=null;
Statement stmt;
ResultSet rs;
News news = null;
String sql="select newsid,title,content from news2"+
" where newsid="+newsid+"";
conn = getConnection();
stmt = conn.createStatement();
rs=stmt.executeQuery(sql);
if(rs.next())
{
news = new News(rs.getInt(1), rs.getString(2),rs.getString(3));
}
rs.close();
stmt.close();
conn.close();
return news;
}
private Connection getConnection() throws SQLException
{
Connection conn = null;
conn = DriverManager.getConnection(url);
return conn;
}
}
说明:这个程序作为示例代码,非常简单,没有考虑异常,更主要的method
如getRecentNews()等,大家可以自己参考实现。
<%@page contentType="text/html;charset=gb2312" %>
<%@page import="news.*" %>
<%
NewsDAO newsDao = new NewsDAO();
News news = newsDao.getNewsByPrimaryKey(1);
if(news != null) {
out.println("Title:"+news.getTitle());
out.println("<br>");
out.println("Body:"+news.getContent());
}
else out.println("Failed.");
%>
说明:这个简化实现其实是DAO模式的省略形式,还应该有interface,dao factory的。
有时间的话,可能以后会给出示例,当然,大家在熟悉oop方式之后,也能够自己补齐。
还有,编译的时候 用 javac news/*.java 就可以了。
如果系统提示找不到News, 那其实是因为你的NewsDAO.java有问题,并非真的是News不在路径上。在同一个包内,一般这样编译就可以的。只不过,编译的错误提示误导人。