首页 > 代码库 > Android查询数据库问题

Android查询数据库问题

============问题描述============


在服务器端的Servlet里处理用户登录我是这么写的,
if (sqlConn.executeQuery("select * from user_test where name =‘"
				+ username + "‘and password =‘" + password + "‘") != null) {
			resp.setContentType("text/xml; charset=UTF-8");
			PrintWriter out = resp.getWriter();
			out.print("用户" + username + "登陆成功");
			out.flush();
			out.close();
} else {
			resp.setContentType("text/xml; charset=UTF-8");
			PrintWriter out = resp.getWriter();
			out.print("用户名或密码不正确");
			out.flush();
			out.close();
}

可是我发现,输入错误的用户名和密码时,executeQuery()仍然能够查询到值,返回com.jdbc.JDBCResultSet@...。按理说用户名和密码不正确的时候不应该有返回值的啊。这是怎么回事?请前辈指教

============解决方案1============


executeQuery查询无论如何都不会返回null的,它返回的是ResultSet对象,所以你应该判断的是ResultSet对象的内容是否为空。

Android查询数据库问题