connection对应多个statement

我的问题来源于这样一道题目

2. 关于jdbc正确说法:

   A 在一个connection上可以创建多个Statement 并且同时执行不同的SQL语句
   B 通过设置一个connection属性就可以做一个数据库事务
   C 通过设置一个Statement属性就可以做一个数据库事务
   D 可以直接在在线结果集Resuleset中更新数据库记录

此题是多选题,题目描述不太清楚
我认为
a  正确   
b  正确   考  connection.setAutoCommit(true);
c  错误
d  正确   存在可更新的ResultSet

 

 

以下为解释------------------------------

 

关于Statement对象:
  前面说过,Statement对象是用来绑定要执行的操作的,在它上面有三种执行方法:
即用来执行查询操作的executeQuery(),用来执行更新操作的executeUpdate()和用来执行
动态的未知的操作的execute().
  JDBC在编译时并不对要执行的SQL语句检测,只是把它看着一个String,只有在驱动
程序执行SQL语句时才知道正确与否.
  一个Statement对象同时只能有一个结果集在活动.这是宽容性的,就是说即使没有
调用ResultSet的close()方法,只要打开第二个结果集就隐含着对上一个结果集的关闭.所以
如果你想同时对多个结果集操作,就要创建多个Statement对象,如果不需要同时操作,那么可
以在一个Statement对象上须序操作多个结果集.
  
  这里我不得不特别说明一下,很多人会用一个Statement进行嵌套查询,然后就来问
我说为什么不能循环?道理上面已经说清楚了.我们来详细分析一下嵌套查询:
  Connection conn = null;
  Statement stmt = null;
  conn = .......;
  stmt = conm.createStatement(xxxxxx);
  ResultSet rs = stmt.executeQuery(sql1);
  while(rs.next()){
    str = rs.getString(xxxxx);
    ResultSet rs1 = stmt.executeQuery(\"select * from 表 where 字段=str\");
  }
当stmt.executeQuery(\"select * from 表 where 字段=str\");赋给rs1时,这时隐含的操作
是已经关闭了rs,你还能循环下去吗?
所以如果要同时操作多个结果集一定要让它他绑定到不同的Statement对象上.好在一个connection
对象可以创建任意多个Statement对象,而不需要你重新获取连结.

另外PreparedStatement还支持接收参数.在预编译后只要传输不同的参数就可以执行,大大
提高了性能.
    
  PreparedStatement ps = conn.prepareStatement(\"select * from 表 where 字段=?\");
  ps.setString(1,参数);
  ResultSet rs = ps.executeQuery();
  
  CallableStatement:是PreparedStatement的子类,它只是用来执行存储过程的.
  CallableStatement sc = conn.prepareCall(\"{call query()}\");
  ResultSet rs = cs.executeQuery();

posted on 2013-03-18 19:19  善敗將軍  阅读(976)  评论(0编辑  收藏  举报

导航