• JDBC的批处理操作三种方式


    SQL批处理是JDBC性能优化的重要武器,经本人研究总结,批处理的用法有三种。
     
    package lavasoft.jdbctest; 

    import lavasoft.common.DBToolkit; 

    import java.sql.Connection; 
    import java.sql.PreparedStatement; 
    import java.sql.SQLException; 
    import java.sql.Statement; 

    /** 
    * JDBC的批量操作三种方式 

    * @author leizhimin 2009-12-4 14:42:11 
    */
     
    public class BatchExeSQLTest { 

            public static void main(String[] args) { 
                    exeBatchStaticSQL(); 
            } 

            /** 
             * 批量执行预定义模式的SQL 
             */
     
            public static void exeBatchParparedSQL() { 
                    Connection conn = null
                    try { 
                            conn = DBToolkit.getConnection(); 
                            String sql = "insert into testdb.book (kind, name) values (?,?)"
                            PreparedStatement pstmt = conn.prepareStatement(sql); 
                            pstmt.setString(1, "java"); 
                            pstmt.setString(2, "jjjj"); 
                            pstmt.addBatch();                     //添加一次预定义参数 
                            pstmt.setString(1, "ccc"); 
                            pstmt.setString(2, "dddd"); 
                            pstmt.addBatch();                     //再添加一次预定义参数 
                            //批量执行预定义SQL 
                            pstmt.executeBatch(); 
                    } catch (SQLException e) { 
                            e.printStackTrace(); 
                    } finally { 
                            DBToolkit.closeConnection(conn); 
                    } 
            } 

            /** 
             * 批量执行混合模式的SQL、有预定义的,还有静态的 
             */
     
            public static void exeBatchMixedSQL() { 
                    Connection conn = null
                    try { 
                            conn = DBToolkit.getConnection(); 
                            String sql = "insert into testdb.book (kind, name) values (?,?)"
                            PreparedStatement pstmt = conn.prepareStatement(sql); 
                            pstmt.setString(1, "java"); 
                            pstmt.setString(2, "jjjj"); 
                            pstmt.addBatch();    //添加一次预定义参数 
                            pstmt.setString(1, "ccc"); 
                            pstmt.setString(2, "dddd"); 
                            pstmt.addBatch();    //再添加一次预定义参数 
                            //添加一次静态SQL 
                            pstmt.addBatch("update testdb.book set kind = 'JAVA' where kind='java'"); 
                            //批量执行预定义SQL 
                            pstmt.executeBatch(); 
                    } catch (SQLException e) { 
                            e.printStackTrace(); 
                    } finally { 
                            DBToolkit.closeConnection(conn); 
                    } 
            } 

            /** 
             * 执行批量静态的SQL 
             */
     
            public static void exeBatchStaticSQL() { 
                    Connection conn = null
                    try { 
                            conn = DBToolkit.getConnection(); 
                            Statement stmt = conn.createStatement(); 
                            //连续添加多条静态SQL 
                            stmt.addBatch("insert into testdb.book (kind, name) values ('java', 'java in aciton')"); 
                            stmt.addBatch("insert into testdb.book (kind, name) values ('c', 'c in aciton')"); 
                            stmt.addBatch("delete from testdb.book where kind ='C#'"); 
                            stmt.addBatch("update testdb.book set kind = 'JAVA' where kind='java'"); 
    //                        stmt.addBatch("select count(*) from testdb.book");                //批量执行不支持Select语句 
                            //执行批量执行 
                            stmt.executeBatch(); 
                    } catch (SQLException e) { 
                            e.printStackTrace(); 
                    } finally { 
                            DBToolkit.closeConnection(conn); 
                    } 
            } 
    }
     
    注意:JDBC的批处理不能加入select语句,否则会抛异常:
    java.sql.BatchUpdateException: Can not issue SELECT via executeUpdate(). 
      at com.mysql.jdbc.StatementImpl.executeBatch(StatementImpl.java:1007)
     

    本文出自 “熔 岩” 博客,请务必保留此出处http://lavasoft.blog.51cto.com/62575/238651

  • 相关阅读:
    H50055:html 页面加载完后再加载js文件 ,url带有时间戳后缀
    H50054:html 页面自动刷新 http-equiv属性
    WebGL_0015:参数值在一定范围内循环变化
    H50053:switch 判断范围
    WebGL_0014:改变相机的刷新颜色
    WebGL_0013:JQuery获取json文件 读取数据
    WebGL_0012:三维讲解导航模板 Icon方式
    H50052:按钮 禁止 选择 拖拽 右键
    滑动窗口的最大值(队列)
    MapReduce程序编写过程
  • 原文地址:https://www.cnblogs.com/azhqiang/p/4038390.html
Copyright © 2020-2023  润新知