Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 421|回复: 0

[JDBC学习]JDBC批处理操作的三种方式

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-11 04:13:19 | 显示全部楼层 |阅读模式
    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
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 07:00 , Processed in 0.365109 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表