我想对于初学者来说,尝试怎样将jsp与数据库连接起来,那是一件迫切想知道的事情。其实,以后在做网站的时候,都要涉及到与数据库的连接。我在这里连的是mysql。之所以选择mysql,因为我喜欢开源的它,与它的平台无关性,和小巧却不失功能性。是一个非常不错
我想对于初学者来说,尝试怎样将jsp与数据库连接起来,那是一件迫切想知道的事情。其实,以后在做网站的时候,都要涉及到与数据库的连接。我在这里连的是mysql。之所以选择mysql,因为我喜欢开源的它,与它的平台无关性,和小巧却不失功能性。是一个非常不错的选择。
首先确定机子上已经安装了mysql。
在这之前做的工作是要在mysql的官方下载它的驱动包,可以免费获得。
将它拷贝到tomcat的common/lib目录下;(我用的测试服务器是tomcat5.0)
然后写如下代码,测试是否连接正常。
java.lang.string strconn;
class.forname(org.gjt.mm.mysql.driver).newinstance();
conn= java.sql.drivermanager.getconnectio(jdbc:mysql://localhost/test,root,);
%>
保存为一个jsp文件,然后放到tomcat的g:\apache software foundation\tomcat 5.0\webapps\root目录下,然后在浏览器里查看此页面,如果不报异常,显示空白页面,则表示已经正确连接上了.接下来的工作,就要测试连接mysql了.
我们完全可以把所有的代码写进一个类里面.如下代码所示:
public class as
{
public static void main(string[] args)
{
string str=null; //
statement stmt=null;
connection conn=null;
try
{
class.forname(com.mysql.jdbc.driver).newinstance();
//加载驱动程序
string url=jdbc:mysql://localhost:3306/qqnumber;
string user=root;
string password=******;
string sql=select * from qqnumber; //
conn=drivermanager.getconnection(url,user,password); //建立连接
stmt=conn.createstatement
(resultset.type_scroll_sensitive,resultset.concur_updatable);
resultset rs=stmt.executequery(sql); //获得数据结果集合 resultset 接口
//提供对数据表的访问。resultset 对象通常是通过执行“语句”来生成的
rs.next();
str=rs.getstring(number);
system.out.println(str);
system.out.println(数据库操作成功,恭喜你);
rs.close();
}
catch(exception e)
{
system.out.println(e);
}
finally
{
if(stmt!=null)
{
try
{
stmt.close();
}
catch(sqlexception e)
{
system.out.println(e);
}
}
if(conn!=null)
{
try
{
conn.close();
}
catch(sqlexception e)
{
system.out.println(e);
}
}
}//finally
}//main()
}
我第一次调试遇到的错误.
com.mysql.jdbc.updatableresultset@1cb25f1数据库操作成功,恭喜你 ,看后面这一句,很明显,这已经成功运行了!可是我要显示的数据查询结果,并没有显示出来.
问题在于resultset rs=stmt.executequery(sql); 所获得的数据结果集合的问题.我们要想显示出来必须将它转化为字符串的形式.
出现下面这一种问题java.sql.sqlexception: before start of result set的原因是:resultset 始终有一个游标指向其当前数据行。最初,游标定位在第一行的前面。next()方法将游标移至下一行。当忘记写next方法时,就会报这样的错误.
(责任编辑:铭铭 mingming_ky@126.com tel:(010)68476636)