jdbc connection是不是可以创建多个statement

乜千凡n2
2013-10-13 · TA获得超过3846个赞
知道小有建树答主
回答量:916
采纳率:0%
帮助的人:2136万
展开全部
�0�2 前面说过,Statement对象是用来绑定要执行的操作的,在它上面有三种执行方法: 即用来执行查询操作的executeQuery(),用来执行更新操作的executeUpdate()和用来执行 动态的未知的操作的execute(). �0�2JDBC在编译时并不对要执行的SQL语句检测,只是把它看着一个String,只有在驱动 程序执行SQL语句时才知道正确与否. �0�2 一个Statement对象同时只能有一个结果集在活动.这是宽容性的,就是说即使没有 调用ResultSet的close()方法,只要打开第二个结果集就隐含着对上一个结果集的关闭.所以 如果你想同时对多个结果集操作,就要创建多个Statement对象,如果不需要同时操作,那么可 以在一个Statement对象上须序操作多个结果集. �0�2�0�2 这里我不得不特别说明一下,很多人会用一个Statement进行嵌套查询,然后就来问 �0�2Connection conn = null; �0�2Statement stmt = null; �0�2conn = .......; �0�2stmt = conm.createStatement(xxxxxx); �0�2ResultSet rs = stmt.executeQuery(sql1); �0�2while(rs.next()){ �0�2�0�2str = rs.getString(xxxxx); �0�2�0�2ResultSet rs1 = stmt.executeQuery(\"select * from 表 where 字段=str\");�0�2}当stmt.executeQuery(\"select * from 表 where 字段=str\");赋给rs1时,这时隐含的操作 所以如果要同时操作多个结果集一定要让它他绑定到不同的Statement对象上.好在一个connection 对象可以创建任意多个Statement对象,而不需要你重新获取连结. 另外PreparedStatement还支持接收参数.在预编译后只要传输不同的参数就可以执行,大大 提高了性能. �0�2�0�2�0�2PreparedStatement ps = conn.prepareStatement(\"select * from 表 where 字段=?\");
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式