在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;
}
展开
 我来答
yaohao_bd
2011-05-09
知道答主
回答量:28
采纳率:0%
帮助的人:0
展开全部
这个说明你的 "select * from register where username='" + username + "'";
在数据库中查出的结果可能为空集,建议你在String sql = "select * from register where username='" + username + "'";后面打印sql:System.out.println(sql);
并将sql在数据库中执行一遍看是否有结果集,在去检查java代码,这个也是一个很好的编码习惯
希望能帮到你;
追问
如何将sql在数据库中执行一遍
追答
就是将打印出来的sql如select * from register where username=‘test’粘贴复制到你的数据库工具或者采用终端运行一遍;
edmund2004
2011-05-10 · TA获得超过360个赞
知道答主
回答量:103
采纳率:0%
帮助的人:94.1万
展开全部
不经过statement,就可以直接rs,恐怕要这个哦,还有就是你可以把where子查询去掉,看试一下呢
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2011-05-09
展开全部
我估计:你的db.query(sql)返回null
所以,rs就是null
更多追问追答
追问
如何解决呢?
追答
不知道你的DatabaseAccess类的具体代码,不好说
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
huang2jing
2011-05-09 · TA获得超过280个赞
知道小有建树答主
回答量:407
采纳率:0%
帮助的人:287万
展开全部
不经过statement,就可以直接rs?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式