• jdbc connection是否可以创建多个statement


    关于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();
  • 相关阅读:
    python开源项目聚合推荐【1】
    python开发--Python实现延时操作的几种方式
    odoo开发笔记 -- 单台物理服务器上,利用docker部署多套odoo应用
    odoo开发笔记 -- odoo官方docker启动原理
    odoo开发笔记 -- odoo官方docker镜像部署
    odoo开发笔记 -- 借助模块queue_job实现异步方法调用
    odoo开发笔记 -- 提高访问安全性的一种方式
    python开发笔记-pymsslq连接操作SqlServer数据库
    运维笔记--Debian/Ubuntu系统离线安装pymssql,连接SqlServer
    python开发笔记-str转字典
  • 原文地址:https://www.cnblogs.com/luckForever/p/7254404.html
Copyright © 2020-2023  润新知