在java中有一个方法,为什么调试时rs总是null?调试时总是从if (rs.next())跳到catch,为什么?
publicbooleancheck(Stringusername){booleanb=false;DatabaseAccessdb=newDatabaseAccess(...
public boolean check(String username) {
boolean b = false;
DatabaseAccess db = new DatabaseAccess();
String sql = "select * from register where username='" + username + "'";
try {
ResultSet rs = db.query(sql);
System.out.println("rs==========="+rs);
if (rs.next())
{
b = false;
}
else
{
b=true;
}
} catch (Exception ee) {
System.out.println("数据操作有误!");
}
db.close();
return b;
} 展开
boolean b = false;
DatabaseAccess db = new DatabaseAccess();
String sql = "select * from register where username='" + username + "'";
try {
ResultSet rs = db.query(sql);
System.out.println("rs==========="+rs);
if (rs.next())
{
b = false;
}
else
{
b=true;
}
} catch (Exception ee) {
System.out.println("数据操作有误!");
}
db.close();
return b;
} 展开
4个回答
展开全部
这个说明你的 "select * from register where username='" + username + "'";
在数据库中查出的结果可能为空集,建议你在String sql = "select * from register where username='" + username + "'";后面打印sql:System.out.println(sql);
并将sql在数据库中执行一遍看是否有结果集,在去检查java代码,这个也是一个很好的编码习惯
希望能帮到你;
在数据库中查出的结果可能为空集,建议你在String sql = "select * from register where username='" + username + "'";后面打印sql:System.out.println(sql);
并将sql在数据库中执行一遍看是否有结果集,在去检查java代码,这个也是一个很好的编码习惯
希望能帮到你;
追问
如何将sql在数据库中执行一遍
追答
就是将打印出来的sql如select * from register where username=‘test’粘贴复制到你的数据库工具或者采用终端运行一遍;
展开全部
不经过statement,就可以直接rs,恐怕要这个哦,还有就是你可以把where子查询去掉,看试一下呢
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2011-05-09
展开全部
我估计:你的db.query(sql)返回null
所以,rs就是null
所以,rs就是null
更多追问追答
追问
如何解决呢?
追答
不知道你的DatabaseAccess类的具体代码,不好说
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不经过statement,就可以直接rs?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询