java语句到这里异常:ResultSet rs = ps.executeQuery();

publicArrayList<User>yaoyiyao(Useru){ArrayList<User>StrangerList=newArrayList<User>()... public ArrayList<User> yaoyiyao (User u) {
ArrayList<User> StrangerList= new ArrayList<User>();
Connection con = DButil.connect();
String sql1 = "UPDATE `user` SET `user`._longitude =?,`user`._latitude = ? where `user`._id=?";
try {
System.out.println("这里是摇一摇内部try!");
PreparedStatement ps = con.prepareStatement(sql1);
ps.setDouble(1, u.getLongitude());
ps.setDouble(2, u.getLatitude());
ps.setInt(3, u.getId());
ps.executeUpdate();
System.out.println("这里执行完摇一摇用户的经纬度的数据库的更新!已经执行了executeUpdate命令!");
ResultSet rs = ps.executeQuery();//executeQuery()方法会把数据库响应的查询结果存放在ResultSet类对象中供我们使用。
System.out.println("这里执行完ResultSet rs = ps.executeQuery();语句!");
while(rs.next()){ //next()函数:通过next来索引,判断是否有下一个记录。一开始就指向内存的首地址,即第一条记录,如果返回值为true,指针会自动指向下一条记录。
Double longitute = rs.getDouble(8);
Double latitude = rs.getDouble(9);
Double longitute1=u.getLongitude();
Double latitude1 = u.getLatitude();
Double distance = GetDistance(latitude, longitute, latitude1, longitute1);
if(distance<=1000){
StrangerList.add((User) rs);
}
}
rs.close();
} catch (SQLException e) {
e.printStackTrace();
} finally {
DButil.close(con);
}
return StrangerList;
}
异常信息:
java.sql.SQLException: Can not issue data manipulation statements with executeQuery().
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.Statement.checkForDml(Statement.java:417)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1383)
at com.way.chat.dao.impl.UserDaoImpl.yaoyiyao(UserDaoImpl.java:126)
at com.way.chat.server.InputThread.readMessage(InputThread.java:99)
at com.way.chat.server.InputThread.run(InputThr...
展开
 我来答
举杯邀天三千雪
2015-05-21 · TA获得超过157个赞
知道小有建树答主
回答量:104
采纳率:100%
帮助的人:78.7万
展开全部
你自己注释的很明白了 //executeQuery()方法会把数据库响应的查询结果存放在ResultSet
这是查询方法,是用来查询的,数据库会吧查询的结果集放在这个ResultSet里面
修改用executeUpdate这个方法
更多追问追答
追问
executeUpdate我在executeQuery()前用过了,用来更新了下数据库,现在想用executeQuery()来查询的呀,executeUpdate只能返回更新记录数啊,我要用到rs.getDouble方法
追答
在你的查询语句前重新获取这个PreparedStatement对象,然后执行查询
简单点说就是
String sql2 = "select * from xxx"
PreparedStatement ps2 = con.prepareStatement(sql2);
有参数写参数没参数调用ps2.executeQuery()
匿名用户
2015-05-21
展开全部
update 语句不能使用executeQuery()方法来执行..
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
chenfei2341
2015-05-21 · TA获得超过845个赞
知道小有建树答主
回答量:396
采纳率:25%
帮助的人:249万
展开全部
将executeQuery()方法改成execute()。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式