mysql 批处理启动_MySQL开启批处理

MySQL默认关闭批处理

开启方法

在原始的URL尾部添加开启指令,如下标注语句

url = jdbc:mysql://localhost:3306/mydb3 ?rewriteBatchedStatements=true

添加批处理

调用preparedStatement中的addBatch()方法,将一句sql添加到批中,循环调用,则可添加大量sql语句到批中。

执行批处理

调用executeBatch()方法,此方法为继承父类Statament中的方法。

批处理可将sql的执行效率大大提升

范例代码

import com.mysql.jdbc.Connection;

import com.mysql.jdbc.PreparedStatement;

import cn.itcast.jdbcUtils.JdbcUtils;

public class Demo5 {

/**

* 批处理

* pstmt对象内部有集合

* 1.用循环向pstmt中添加sql参数,它有自己的模板,使用一组参数与模板可以匹配出一条sql语句

* 2.最后调用执行批方法,完成向数据库发送

* @throws Exception

*/

public void fun5() throws Exception {

/*

* pstmt:

* >添加参数到批中

* >执行批

*/

Connection con = JdbcUtils.getConnection();

String sql = "insert into t_stu values(?,?,?,?)";

PreparedStatement pstmt = (PreparedStatement) con.prepareStatement(sql);

//批量添加数据

for(int i = 0;i < 10000;i++) {

pstmt.setInt(1, i+1);

pstmt.setString(2, "stu_"+i);

pstmt.setInt(3, i);

pstmt.setString(4,i%2==0? "男":"女");

pstmt.addBatch();//添加批,这一组参数就保存到集合中了

}

long start = System.currentTimeMillis();

pstmt.executeBatch();//执行批

long end = System.currentTimeMillis();

System.out.println(end-start);

}

public static void main(String[] args) throws Exception {

Demo5 demo5 = new Demo5();

demo5.fun5();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值