zoukankan      html  css  js  c++  java
  • JDBC自动提交和批处理操作

    今天用JDBC与数据库进行交互的时候,报错如下:

    *********************************************************************************************
    com.ibm.db2.jcc.b.SqlException: [jcc][t4][10251][10308][3.53.70] 正在连接上执行事务时,请求了 java.sql.Connection.close()。
    事务仍然保持活动状态,不能关闭连接。 ERRORCODE=-4471, SQLSTATE=null
    at com.ibm.db2.jcc.b.bd.a(bd.java:660)
    at com.ibm.db2.jcc.b.bd.a(bd.java:60)
    at com.ibm.db2.jcc.b.bd.a(bd.java:120)
    at com.ibm.db2.jcc.b.jb.t(jb.java:1105)
    at com.ibm.db2.jcc.b.jb.w(jb.java:1128)
    at com.ibm.db2.jcc.b.jb.u(jb.java:1114)
    at com.ibm.db2.jcc.b.jb.close(jb.java:1098)
    at com.softtone.excution.Odb.close(Odb.java:192)
    at com.softtone.excution.Odb.main(Odb.java:219)
    ************************************************************************************************ 

    总结如下:

    1.JDBC默认是自动提交的,对于查询可以不用修改设置

    2.JDBC中对于增、删、改、查的修改操作,为保持数据的完整性,一般都是把修改操作组装成一个事务。需要在修改之前调用connection对象的setAutoCommit(false)这个方法,在调用完statement对象的executeBatch()批量修改方法后,后面需要跟一个connection对象的commit()方法。否则,在最后调用conn.close()方法关闭连接会抛出事务正在活动,不能关闭JDBC连接的异常。

    注:setAutoCommit(false)放在具体的操作里面,一般是修改操作之前。查询操作就不用设置。

    示例:

    public class JdbcTest {
        public void execute(){
            Connection conn = null;
            Statement stmt = null;
            ResultSet rs = null;
            try {
                conn = JdbcUtil.getConnection(Constants.URL, Constants.USERNAME, Constants.PASSWORD);
                String sqlQuery = "select distinct ID from table a";
                stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
                rs = stmt.executeQuery(sqlQuery);
                StringBuffer sb1 = new StringBuffer();
                while(rs.next()){
                    sb1.append("'"+rs.getString(1)+"'");
                    if(!rs.isLast()){
                        sb1.append(",");
                    }
                }
                rs.close();
                String Id = sb1.toString();
                if(!"".equals(Id)){
                    //为保持数据的一致性,把多个对数据库的删除操作作为一个事务,禁止自动提交
                    conn.setAutoCommit(false);
                    String sqlDelete1 = "delete from table1 where ID in (" + Id +")";
                    stmt.addBatch(sqlDelete1);
                    String sqlDelete2 = "delete from table2 where ID in (" + Id +")";
                    stmt.addBatch(sqlDelete2);
                    stmt.executeBatch();
                    conn.commit();
                }
                stmt.close();
                conn.close();
                
            } catch (SQLException e) {
                e.printStackTrace();
            }finally{
                JdbcUtil.free(rs, stmt, conn);
            }
        }
    }
  • 相关阅读:
    转游戏开发做的第一款手机网游的经历和体会
    cocos2d-x 单点事件用法
    cocos2d-x编译成android 以及android开发环境一些经验分享
    apk 反编译用法 mac上apktool
    cocos2d-x 中LUA和平台之间的函数调用理解
    项目经验
    sprintf 的基本用法
    html5标签 ----------- canvas vue / html
    vue 基于element组件库实现表格下多个子级展示
    vue基于proxy实现服务器反向代理功能
  • 原文地址:https://www.cnblogs.com/tanglc/p/3689326.html
Copyright © 2011-2022 走看看