JDBC学习(七、批处理操作)

本文介绍了Java中JDBC的批量操作(batch)机制,通过对比使用Statement和PreparedStatement在批处理和非批处理情况下的示例代码,展示了批量处理在效率上的优势。尽管MySQL可能不直接支持PreparedStatement的性能优化和批量操作,但在新的JDBC驱动中,可以通过设置rewriteBatchedStatements=true进行优化,提升性能。
摘要由CSDN通过智能技术生成

一、批量操作(batch)

    当需要成批插入或者更新记录时,可以采用Java的批量更新机制,这一机制允许多条语句一次性提交给数据库批量处理。通常情况下比单独提交处理更有效率.


JDBC的批量处理语句包括下面两个方法:
addBatch(String sql):添加需要批量处理的SQL语句或是参数;
executeBatch();执行批量处理语句;

通常我们会遇到两种批量执行SQL语句的情况:
多条SQL语句的批量处理; :Statement
一个SQL语句的批量传参; :PreparedStatement


需求:同时向t_student表,插入1000条数据,在JDBC中,MySQL不支持批量操作。
-------------------------------------------------------------------------
Statement 批处理 : 一次性可以执行多条sql语句,需要编译多次。
应用场景:系统初始化 (创建表,创建数据等)
添加sql语句,st.addBatch(sql)   --添加sql语句
批量处理sql语句,int[] st.executeBatch()
清除缓存: st.clearBatch();
-------------------------------------------------------------------------
PreparedStatement 批处理 : 执行一条sql语句,编译一次,执行sql语句的参数不同。
应用场景:表数据初始化
添加批量参数:psmt.addBatch()    --添加实际参数,执行之前,需要执行psmt.setXxx()设置实际参数
执行批处理:int[] psmt.executeBatch()
清除缓存:pstm.clearBatch();


1.使用Statement完成,没有批处理

代码演示:

public void saveByStatement() {
	// 声明资源对象
	Connection conn = null;
	Statement stmt = null;
	// 贾琏欲执事
	try {
		// 1.加载注册驱动
		Class.forName("com.mysql.jdbc.Driver");
		// 2.获取连接对象
		conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "rootroot");
		// 3.获取语句对象
		stmt = conn.createStatement();
		// 循环5000次
		long begin = System.currentTimeMillis();
		for (int i = 0; i < 1000; i++) {
			String sql = 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值