码迷,mamicode.com
首页 > 数据库 > 详细

MySQL的批处理

时间:2016-11-09 22:19:25      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:程序   参数   class   mysql参数   批处理   dstat   状态   代码   tca   

MySQL默认是关闭批处理的,所以我们在默认状态下(批处理未打开)向数据库中存入10000条数据,核心代码如下:

package cn.itcast.demo5;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import org.junit.Test;
import cn.itcast.demo3.JdbcUtils;
public class Demo5 {
    @Test
    public void fun5() throws SQLException {
        /*
         * pstmt:
         * > 添加参数到批中
         * > 执行批!
         */
        Connection con = JdbcUtils.getConnection();
        String sql = "INSERT INTO t_stu VALUES(?,?,?,?)";
        PreparedStatement pstmt = 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);
    }
}

上述程序执行结束耗费时间412764MS

这是打开MySQL的批处理,打开方式:

  将MySQL参数  url=jdbc:mysql://localhost:3306/exam

  改为        url=jdbc:mysql://localhost:3306/exam?rewriteBatchedStatements=true

再次执行程序,耗时301MS,速度快了1000倍以上!

MySQL的批处理

标签:程序   参数   class   mysql参数   批处理   dstat   状态   代码   tca   

原文地址:http://www.cnblogs.com/fengmingyue/p/6048473.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!