`
naicj
  • 浏览: 25676 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

关于PreparedStatement.addBatch()方法

阅读更多

 

关于PreparedStatement.addBatch()方法  

 

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

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

   Connection    connection =getConnection();

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

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();

引自::http://hi.baidu.com/charlielogic/blog/item/69b8775536da18c0b645ae36.html/cmtid/46c7ef5846b338d29d820434


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();
    };

分享到:
评论

相关推荐

    Oracle addBatch()用法实例详解

    Oracle的`addBatch()`方法是PreparedStatement接口中的一个关键功能,用于在执行批量处理时添加SQL语句。批量处理是提高数据库操作效率的重要手段,尤其是在插入、更新或删除大量数据时。下面将详细介绍`addBatch()`...

    【IT十八掌徐培成】Java基础第23天-03.ppst-addBatch-executeBatch.zip

    批量处理的核心在于`PreparedStatement`的`addBatch`和`executeBatch`方法。`PreparedStatement`是`Statement`的一个子类,它允许预编译SQL语句,提高了代码的可读性和安全性,并且在处理批量操作时更为高效。 首先...

    MySQL数据库

    ####Statement和PreparedStatement - PreparedStatement预编译的SQL执行对象 1. 可以避免SQL注入 因为在编译的时候已经把SQL的逻辑固定,不会因为替换进去的内容改变逻辑 2. 如果SQL中涉及变量 相比Statement的字符...

    sql2005 批量更新问题的解决方法

    sm.addBatch(sql1); sm.addBatch(sql2); … sm.executeBatch() 用Statement的好处就是每次可以直接传一个SQL语句进去,不用管那么多。可是在数据量比较大的时候,应该会对效率有影响。不建议使用。 ...

    用java程序怎么实现200ms往数据库中插入10000条数据.doc

    使用`PreparedStatement.addBatch()`方法来收集要插入的值,然后使用`PreparedStatement.executeBatch()`一次性执行所有插入操作。 ```java String insertStr = "INSERT INTO abc VALUES (?, ?)"; ...

    jdbc批量插入大字段

    4. **批量执行**:调用`PreparedStatement.addBatch()`将每条插入语句添加到批处理队列中。当积累了一定数量的语句或者操作完成后,使用`PreparedStatement.executeBatch()`一次性提交所有语句。这种方式减少了与...

    使用 JDBC 的高级数据库操作

    1. 创建批处理:`PreparedStatement.addBatch()` 2. 执行批处理:`PreparedStatement.executeBatch()` 3. 提交批处理后记得清空批处理队列:`PreparedStatement.clearBatch()` 七、连接池管理 为了优化性能,通常...

    【IT十八掌徐培成】Java基础第23天-03.ppst-addBatch-executeBatch - 副本.zip

    1. `addBatch()`方法:此方法用于将一条SQL命令(通常是插入、更新或删除)添加到批处理命令列表中。当你调用`addBatch()`时,你实际上是在告诉JDBC驱动程序,你想要将这个SQL操作加入到待处理的批次中。例如,如果...

    JDBC的常用方法

    为了防止SQL注入,JDBC提供了一个安全的方法:使用PreparedStatement。在编写SQL语句时,使用问号(?)作为占位符,然后通过预编译的对象设置参数值。例如: ```java // 获取数据库连接 Connection connection = ...

    关于JAVA数据库基本操作

    ### 关于JAVA数据库基本操作 #### 一、Java数据库操作基本流程 在Java中进行数据库操作通常遵循以下步骤: 1. **取得数据库连接** - 使用`DriverManager`获取数据库连接: ```java String className = "oracle...

    批量处理JDBC语句提高处理速度

    批量处理通过Statement或PreparedStatement对象实现,这两个类都提供了支持批量处理的方法。批量处理的基本思路是将多个SQL语句一次性提交给数据库,而不是逐条执行,这样可以避免多次数据库连接和断开,显著提高...

    【IT十八掌徐培成】Java基础第23天-02.sql注入-preparedstatement-批量插入 - 副本.zip

    在上述代码中,addBatch()方法将一条插入语句添加到批处理队列,最后通过executeBatch()一次性提交所有操作。这种方式减少了与数据库的交互次数,显著提升了性能。 总的来说,PreparedStatement和批量插入是Java...

    JDBC的批量处理语句

    对于第二种情况,我们可以使用 JDBC 的批量处理语句,创建一个 PreparedStatement 对象,然后 addBatch 多条参数,最后执行 executeBatch() 方法。这可以减少执行次数,提高执行效率。 例如: ```java ...

    使用JDBC的批处理功能

    在JDBC中,批处理主要通过Statement或PreparedStatement对象的addBatch()方法来实现,然后通过executeBatch()方法执行整个批处理队列。 二、批处理的优势 1. 性能提升:批处理减少了网络传输的次数,因为多个SQL...

    java导入txt到数据库 从数据库导出txt

    如果数据量大,考虑使用批处理(`PreparedStatement.addBatch()`和`PreparedStatement.executeBatch()`)以提高效率。 5. **执行SQL**:使用`Statement`或`PreparedStatement`对象执行插入操作。 6. **关闭资源**...

    Excle导入数据库和数据库导入到Excle中.doc

    此外,为了提高性能和减少资源消耗,建议使用批处理操作(`PreparedStatement.addBatch()`和`pre.executeBatch()`)来批量插入数据。 在实际应用中,还要考虑异常处理和性能优化,比如使用连接池管理数据库连接,...

    jdbc 增删改查事物处理, 批处理,以及预编译示例代码

    使用`Statement`的`addBatch()`方法添加SQL语句到批处理队列,然后通过`executeBatch()`执行整个批次。 - **批处理在JDBC中的应用**:批量插入、更新或删除,尤其适用于大数据量操作。 4. **预编译SQL语句...

    mysql-connector-java-5.1.rar

    8. **批处理**:通过`PreparedStatement.addBatch()`和`Statement.executeBatch()`,可以批量执行多条SQL语句,提高执行效率。 9. **异常处理**:MySQL Connector/J会抛出`SQLException`及其子类异常,如`...

Global site tag (gtag.js) - Google Analytics