java读取MySQL数据库

publicvoidconnectDatabase(){driver="com.mysql.jdbc.Driver";url="jdbc:mysql://localhos... public void connectDatabase(){
driver = "com.mysql.jdbc.Driver";
url = "jdbc:mysql://localhost:3306/library";
user = "root";
password = "123456";
try{
Class.forName(driver);
Connection conn = DriverManager.getConnection(url, user, password);
statement = conn.createStatement();
sql = "select * from user where id = '" + licenseid.getText() + "' and password = '" + pwd.getText() + "'";
ResultSet rs = statement.executeQuery(sql);
if(!rs.isBeforeFirst()){
JOptionPane.showMessageDialog(frame, "Wrong password!");
}
else
{
String value = rs.getString("name");
JOptionPane.showMessageDialog(frame, rs.getString(3) + "Welcome to library!");
}
}catch(ClassNotFoundException e) {
JOptionPane.showMessageDialog(frame, "Sorry,can`t find the Driver!");
}catch(SQLException e) {
e.printStackTrace();
}catch(Exception e) {
e.printStackTrace();
}
}

String value = rs.getString("name");这一步读取数据库中对应用户的名字(属性定义为char[30]),但是程序运行到这一行后,就会抓到错误
catch(SQLException e) {
e.printStackTrace();
哪里错了?
改怎么正确读取数据库中的数据?
展开
 我来答
tomiscat2009
2009-04-01 · TA获得超过2434个赞
知道小有建树答主
回答量:380
采纳率:0%
帮助的人:538万
展开全部
在String value = rs.getString("name"); 之前要先rs.next();一下

你用这个来判断密码错误?
if(!rs.isBeforeFirst()){
JOptionPane.showMessageDialog(frame, "Wrong password!");
}

isBeforeFirst() 的意思是:获取光标是否位于此 ResultSet 对象的第一行之前。
nietiezheng
2009-04-01 · TA获得超过5536个赞
知道大有可为答主
回答量:3132
采纳率:87%
帮助的人:1226万
展开全部
把错误信息发出来,不然不好诊断
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
韦涵涵
2009-04-01 · TA获得超过3892个赞
知道大有可为答主
回答量:1034
采纳率:100%
帮助的人:1511万
展开全部
这个真的不好说...看起来没有错误...想帮你...可是不运行看不到结果不好说.....
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式