zoukankan      html  css  js  c++  java
  • [转]关于PreparedStatement.addBatch()方法

    Statement和PreparedStatement的区别就不多废话了,直接说PreparedStatement最重要的addbatch()结构的使用.

    1.建立链接,(打电话拨号 )    

       Connection    connection =getConnection();

    2.不自动 Commit (瓜子不是一个一个吃,全部剥开放桌子上,然后一口舔了)

    //          setAutoCommit(true):sql命令的提交(commit)由驱动程序负责
    //          setAutoCommit(false):sql命令的提交由应用程序负责,程序必须调用commit或者rollback方法

     connection.setAutoCommit(false);  

    3.预编译SQL语句,只编译一回哦,效率高啊.(发明一个剥瓜子的方法,以后不要总想怎么剥瓜子好.就这样剥.)
    PreparedStatement statement = connection.prepareStatement("INSERT INTO TABLEX VALUES(?, ?)");   

    4.来一个剥一个,然后放桌子上

    //记录1
    statement.setInt(1, 1); 
    statement.setString(2, "Cujo"); 
    statement.addBatch();   

    //记录2
    statement.setInt(1, 2); 
    statement.setString(2, "Fred"); 
    statement.addBatch();   

    //记录3
    statement.setInt(1, 3); 
    statement.setString(2, "Mark"); 
    statement.addBatch();   

    //批量执行上面3条语句. 一口吞了,很爽
    int [] counts = statement.executeBatch();   

    //Commit it 咽下去,到肚子(DB)里面
    connection.commit();


    stmt.addBatch("update  TABLE1 set 题目="盛夏话足部保健1"   where id="3407"");
    stmt.addBatch("update  TABLE1 set 题目="夏季预防中暑膳食1" where id="3408""); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("11","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("12","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("13","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("14","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("15","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("16","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("17","12","13","","")"); 
    stmt.addBatch("INSERT INTO  TABLE1  VALUES("18","12","13","","")"); 

    int [] updateCounts=stmt.executeBatch(); 
    cn.commit();

    例如:

        public static void execteBatch(Connection conn)throws Exception{
            String sql1 = "delete from student where id =3 ";
            String sql2 = "delete from student where id =5 ";
            String sql3 = "delete from student where id =6 ";
            String sql4 = "delete from student where id =7 ";
            PreparedStatement pstmt = conn.prepareStatement(sql1);
            pstmt.addBatch();
            pstmt.addBatch(sql2);
            pstmt.addBatch(sql3);
            pstmt.addBatch(sql4);
            pstmt.executeBatch();
        };

  • 相关阅读:
    谷歌地图嵌入配置及代码生成器
    Easyui几种布局方式的使用
    9款超酷的jQuery/CSS3插件
    8款功能强大的最新HTML5特效实例
    《大话操作系统——做坚实的project实践派》(2)
    1、libgdx简单介绍
    自己定义Android Dialog
    纪念2014 TI DSP大奖赛
    LeetCode 96:Unique Binary Search Trees
    Chromium网页输入事件捕捉和手势检測过程分析
  • 原文地址:https://www.cnblogs.com/qiuhong10/p/8417848.html
Copyright © 2011-2022 走看看