[JDBC]批处理

一.code

复制代码
import org.junit.jupiter.api.Test;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;

public class TestBatch {
    @Test
    public void test1()throws Exception{
        //没有用批处理的功能
        long start = System.currentTimeMillis();

        //建立连接
        String url = "jdbc:mysql://localhost:3306/jdbctest";
        String user = "root";
        String pwd = "123456";
        Connection connection = DriverManager.getConnection(url, user, pwd);

        //编写sql
        String sql = "insert into t_department values(null,?,?)";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        for(int i=1; i<=2000; i++){
            preparedStatement.setObject(1, "模拟部门名称" + i );
            preparedStatement.setObject(2, "模拟部门简介" + i );
            preparedStatement.executeUpdate();
            //执行2000遍
        }
        preparedStatement.close();
        connection.close();

        long end = System.currentTimeMillis();
        System.out.println("耗时:" +(end-start));
        //耗时:6554
    }

    @Test
    public void test2()throws Exception{
        //使用批处理功能
        long start = System.currentTimeMillis();

/*        MySQL服务器端,默认批处理功能没有开启。需要通过参数告知mysql服务器,开启批处理功能。
        在url后面再加一个参数 rewriteBatchedStatements=true*/
        //建立连接
        String url = "jdbc:mysql://localhost:3306/jdbctest";
        String pwd = "123456";
        String user = "root";
        Connection connection = DriverManager.getConnection(url, user, pwd);

        //编写sql
        String sql = "insert into t_department values(null,?,?)";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        for(int i=2001; i<=4000; i++){
            preparedStatement.setObject(1, "模拟部门名称a" + i );
            preparedStatement.setObject(2, "模拟部门简介b" + i );
            preparedStatement.addBatch();//先攒着
        }
        preparedStatement.executeBatch();//执行批处理功能

        preparedStatement.close();
        connection.close();

        long end = System.currentTimeMillis();
        System.out.println("耗时:" +(end-start));//耗时:729
    }
}
相关推荐
lee_curry1 天前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣1 天前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿1 天前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵1 天前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
野生技术架构师1 天前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂1 天前
多表关联大平层转JSON树形结构
java·json
ja哇1 天前
大厂面试高频八股
java·面试·职场和发展
yoyo_zzm1 天前
Laravel6.x新特性全解析
java·spring boot·后端
Nick_zcy1 天前
小说在线阅读网站和小说管理系统 · 功能全解析
java·后端·python·springboot·ruoyi