java mysql批处理_数据库批处理-使用prepareStatement对象实现批处理

本文介绍了Java中使用PreparedStatement对象实现数据库批处理的方法,通过addBatch()和executeBatch()批量执行SQL语句,提高了数据插入的效率。文章还提及了在Druid连接池中配置批处理以及创建测试表并执行批处理操作的示例代码,展示了如何快速插入大量数据。
摘要由CSDN通过智能技术生成

什么是批处理

批处理(Batch)操作数据库批处理指的是一次操作中执行多条SQL语句,相比于一次执行一条,多次执行,效率提高很多

当向数据库添加大量数据时,需要用到批处理

实现批处理Statement与prepareStatement都可以实现批处理

常用方法介绍方法说明void addBatch()将给定的SQL命令添加到此Statement对象的当前命令列表中

int[] executeBatch()每次提交一批命令到数据库中执行void addBatch() - 通过调用方法executeBatch()可以批量执行此列表中的命令

int[] executeBatch() - 如果所有的命令都成功执行了,那么返回一个数组,这个数组是说明每条命令所影响的行数

配置文件中开启批处理

mysql的批处理是默认关闭的,所以需要加一个参数显式打开mysql数据库批处理.

在url中添加rewriteBatchedStatements=true

添加后的url是jdbc:mysql://localhost:3306/lianxi01?characterEncoding=UTF-8&useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC&rewriteBatchedStatements=true

本文是基于Druid连接池(创建方式参考创建Druid连接池),所以在配置文件druid.properties中将url修改为上述语句

在数据库中创建表

回到数据库中创建表,目的是稍候使用批处理操作向表中批量插入语名CREATE TABLE testBatch (

id INT PRIMARY KEY AUTO_INCREMENT,

uname VARCHAR(50)

);

使用Druid执行批处理操作package com.bigdata.task06;

import utils.DruidUtils;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.SQLException;

/**

* 项目描述: 使用QueryRunner类query方法执行查询操作

*/

public class BatchTest {

public static void main(String[] args) {

Connection connection = null;

PreparedStatement preparedStatement = null;

try {

// 1.获取连接

connection = DruidUtils.getConnection();

// 2.创建占位符形式的sql语句

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

// 3.获取语句执行平台,即创建prepareStatement对象

preparedStatement = connection.prepareStatement(sql);

// 4.使用for循环替换sql语名中的占位符

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

preparedStatement.setString(1,"乌冬面" + i + "号");

preparedStatement.addBatch();

}

long start = System.currentTimeMillis();

// 5.执行批处理

int[] ints = preparedStatement.executeBatch();

long end = System.currentTimeMillis();

System.out.println("插入77777条数据耗时:" + (end-start) + "ms");

} catch (SQLException throwables) {

throwables.printStackTrace();

} finally {

// 6.关闭对象

DruidUtils.close(connection,preparedStatement);

}

}

}

bf6d28353ad7235c82c750af49aef39b.png

不到一秒钟就插入了7W+条数据,接下来回数据库看一下

数据库中查看数据验证

4a936d16b279639ad5cbdf8ebf7df6a6.png

53349e424c602707b121436446bb528b.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值