package lavasoft.jdbctest; 

import lavasoft.common.DBToolkit; 

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

/** 
* JDBC的批量操作三种方式 
*/ 
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)

最新文章

  1. ubuntu16.04下安装openssh-server报依赖错误的解决方法
  2. oracle--varchar2
  3. css分割线 文字居中的7种实现方式
  4. Asp.net web服务处理程序(第六篇)
  5. iOS 开发常用设置
  6. cocos2dx新建工程分析
  7. 从零開始学android<SeekBar滑动组件.二十二.>
  8. ural1752 Tree 2
  9. IP核之初——FIFO添加以太网MAC头部
  10. java傻瓜简单100%一定看的懂新手安装教程
  11. php分布式redis实现session共享
  12. 原生JS模拟百度搜索关键字与跳转
  13. 18、实现strStr()
  14. SQL中ON和WHERE的区别(转)
  15. 在WINDOWS服务器下设置MARIADB自动备份的方法
  16. wave
  17. bzoj1791[IOI2008]Island岛屿(基环树+DP)
  18. Docket 使用命令
  19. windows下更换pip源
  20. 【题解】Luogu P3740 [HAOI2014]贴海报

热门文章

  1. [LeetCode] Search in Rotated Sorted Array II 在旋转有序数组中搜索之二
  2. .NET跨平台之旅:在Linux上将ASP.NET 5运行日志写入文件
  3. 1001 数组中和等于K的数对 1090 3个数和为0
  4. 【WPF】wpf image控件加载网络图片不显示问题,
  5. highcharts .net导出服务 和 两种导出方式
  6. jQuery 树形菜单
  7. 常用的js方法,包括表单校验的一些方法
  8. R 查看函数源代码
  9. TF-IDF算法学习报告
  10. 101 LINQ Samples