mysql的批量操作_mysql 批量操作

批量操作一般都会有,这里也分享一下我的经验:

用的早期的:mysql-connector-java-5.0.7-bin.jar

关于连接代码看:http://greemranqq.iteye.com/admin/blogs/1830200

这里我发现的问题是:

1.将自动提交设置成false, 不然批量操作会失去效果

2.网上说:jdbc.url = jdbc:mysql://localhost:3306/test?rewriteBatchedStatements=true

这只成true,才有批量效果。我设置成false 和true 都没什么影响

求同志们多指导,详细原因不了解

数据库层的操作:

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.SQLException;

public class DaoUtil {

private static Connection conn;

// 批量插入语句

static String batchSql = "insert into newtable values(?,?)";

// 普通插入大量数据

public static void insertBatch1(String batchSql) {

conn = ConnectionUtil.getConnection();

try {

PreparedStatement ps = conn.prepareStatement(batchSql);

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

ps.setInt(1, i);

ps.setString(2, "name");

ps.addBatch();

}

ps.executeBatch();

} catch (SQLException e) {

ConnectionUtil.rollback(conn);

e.printStackTrace();

}finally{

ConnectionUtil.colse(conn);

}

}

// 批量插入

public static void insertBatch2(String batchSql) {

conn = ConnectionUtil.getConnection();

try {

// 自动提交默认是true,就会按条执行,执行效率没有优化

conn.setAutoCommit(false);

PreparedStatement ps = conn.prepareStatement(batchSql);

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

ps.setInt(1, i);

ps.setString(2, "name");

ps.addBatch();

}

ps.executeBatch();

conn.commit();

} catch (SQLException e) {

ConnectionUtil.rollback(conn);

e.printStackTrace();

}finally{

ConnectionUtil.colse(conn);

}

}

public static void main(String[] args) {

//long begin1 = System.currentTimeMillis();

//insertBatch1(batchSql);

//long end1 = System.currentTimeMillis();

//System.out.println("普通插入10000条数据时间:"+(end1-begin1));

long begin2 = System.currentTimeMillis();

insertBatch2(batchSql);

long end2 = System.currentTimeMillis();

System.out.println("批量插入10000条数据时间:"+(end2-begin2));

}

}

这里 的简单记录,大概效率是10倍左右。有些细节我也没注意了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值