使用JDBC和Mybatis批量插入数据

项目结构

使用传统的JDBC进行批量数据的插入

关键核心类

JdbcUtil.java

package com.imooc.mybatis.util;

import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;

public class JdbcUtil {
    public JdbcUtil() {
    }

    public static void commonUpdate(String sql, Object... param) {
        Connection conn = null;
        PreparedStatement preparedStatement = null;

        try {
            conn = getConnection();
            preparedStatement = conn.prepareStatement(sql);

            for(int i = 0; i < param.length; ++i) {
                preparedStatement.setObject(i + 1, param[i]);
            }

            preparedStatement.executeUpdate();
        } catch (Exception var8) {
            var8.printStackTrace();
        } finally {
            closeResources(conn, preparedStatement, (ResultSet)null);
        }

    }

    //提交事务
    public static void commit(Connection conn){
        try {
            conn.commit();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public static void begin(Connection conn){
        if(conn != null){
            try {
                conn.setAutoCommit( false );
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    public static Connection getConnection(){
        Properties properties = new Properties();
        InputStream is = JdbcUtil.class.getClassLoader().getResourceAsStream( "mysql2.properties" );
        try {
            properties.load(is);
        } catch (IOException e) {
            e.printStackTrace();
        }
        String driver = properties.getProperty("jdbc.driver");
        String username = properties.getProperty("jdbc.username");
        String password = properties.getProperty("jdbc.password");
        String url = properties.getProperty("jdbc.url");
        try {
            //注册驱动
            Class.forName(driver);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        try {
            return DriverManager.getConnection(url, username, password);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return null;
    }

    public static void closeResources(Connection conn, Statement statement, ResultSet resultSet) {
        if (null != conn) {
            try {
                conn.close();
            } catch (SQLException var6) {
                var6.printStackTrace();
            }
        }

        if (null != statement) {
            try {
                statement.close();
            } catch (SQLException var5) {
                var5.printStackTrace();
            }
        }

        if (null != resultSet) {
            try {
                resultSet.close();
            } catch (SQLException var4) {
                var4.printStackTrace();
            }
        }

    }

    public static void main(String[] args) throws Exception {
        System.out.println(getConnection());
    }
}

mysql2.peoperties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?rewriteBatchedStatements=true&amp;useUnicode=true&amp;characterEncoding=utf-8
jdbc.username=root
jdbc.password=123456

进行测试:JdbcTest.java

import com.imooc.mybatis.util.JdbcUtil;
import org.junit.Test;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

public class JdbcTest {

    private Connection conn = JdbcUtil.getConnection();
    private PreparedStatement preparedStatement = null;
    private String sql = "insert into person(username,email) values(?,?)";
    private long startTime,endTime;

    /**
     * 方式一,使用for循环,来一条一条的插入数据,用时两千多毫秒
     */
    @Test
    public void demo1(){

        JdbcUtil.begin( conn );//set AutoCommit = False
        try {
            preparedStatement = conn.prepareStatement( sql );

            startTime = System.currentTimeMillis();

            for(int i=0;i<10000;i++){
                preparedStatement.setString( 1,"user" + (i + 1) );
                preparedStatement.setString( 2,"adog@" + (i+1) + ".com" );
                //这一步不能省略
                preparedStatement.executeUpdate();//执行
            }

            JdbcUtil.commit( conn );//提交事务
            //关闭连接
            JdbcUtil.closeResources( conn,preparedStatement,null );
            endTime = System.currentTimeMillis();
            System.out.println( endTime - startTime );

        } catch (SQLException e) {
            e.printStackTrace();
        }
    }


    /**
     * 方式二,使用BatchUpdate批量插入,用时两百多毫秒
     */
    @Test
    public void testBatchUpdate(){

        JdbcUtil.begin( conn );//set AutoCommit = False
        try {
            preparedStatement = conn.prepareStatement( sql );

            startTime = System.currentTimeMillis();

            for(int i=0;i<10000;i++){
                preparedStatement.setString( 1,"user" + (i + 1) );
                preparedStatement.setString( 2,"adog@" + (i+1) + ".com" );
                preparedStatement.addBatch();
                //这一步不能省略(进行批量更新)
                if((i+1)%1000 == 0){//批量处理,1000条数据作为一批,时间254毫秒
                    preparedStatement.executeBatch();
                    preparedStatement.clearBatch();
                }
            }

            JdbcUtil.commit( conn );
            //关闭连接
            JdbcUtil.closeResources( conn,preparedStatement,null );
            endTime = System.currentTimeMillis();
            System.out.println( endTime - startTime );

        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

}

使用Mybatis进行批量数据的插入

1)借助foreach标签

1.准备Dao接口

void insertPersons(List<Person> list);

2.准备mapper文件

<!--因为参数是List或Collection类型的,所以collocton="这里使用list或者collection都可以"-->
    <insert id="insertPersons">
        insert into person(username,email) values
        <foreach collection="collection" separator="," index="i" item="person">
            (#{person.username},#{person.email})
        </foreach>
    </insert>

3.进行测试

/**
     * 测试Mybatis使用foreach,插入多条数据
     */
    @Test
    public void testInsertPersons(){
        List<Person> list = new ArrayList<Person>(  );
        for(int i=0;i<5;i++){
            Person person = new Person();
            person.setUsername( "mick" + i);
            person.setEmail( "mick@" + i + ".com" );
            list.add( person );
        }
        //注:这里同时插入多条记录,需要最终提交事务,这里Mybatis使得默认事务不是自动提交的。
        personMapper.insertPersons( list );
        sqlSession.commit();
    }

2)借助MySQL数据库连接属性allowMultiQueries=true

1.准备DAO接口

void insertPersons2(List<Person> list);

2.准备mappe文件

<!--Mybatis 根据allowMultiQueries进行批量插入数据-->
    <insert id="insertPersons2">
        <foreach collection="list" item="person" separator=";">
            insert into person(username,email) values (#{person.username},#{person.email})
        </foreach>
    </insert>

3.准备测试

/**
     * 测试Mybatis基于allowMultiQueries,插入多条数据
     */
    @Test
    public void testInsertPersons2(){
        List<Person> list = new ArrayList<Person>(  );
        for(int i=0;i<5;i++){
            Person person = new Person();
            person.setUsername( "adog" + i);
            person.setEmail( "adog@" + i + ".com" );
            list.add( person );
        }
        //注:这里同时插入多条记录,需要最终提交事务,这里Mybatis使得默认事务不是自动提交的。
        personMapper.insertPersons2( list );
        sqlSession.commit();
    }

3)基于SqlSession的ExecutorType进行批量添加(这种方式适合处理大批量数据,是Mybatis向数据库中插入大量数据的最终解决方案)

1.准备DAO接口

void insertByExecutorBatch(Person person);

2.准备mapper文件

<!--使用executor进行批量数据插入-->
    <insert id="insertByExecutorBatch" parameterType="Person">
        insert into person(username,email) values(#{username},#{email})
    </insert>

3.准备测试

@Test
    public void testBatchForExecutor(){
        long beginTime,endTime;
        beginTime = System.currentTimeMillis();
        this.sqlSession = SqlSessionFactoryUtil.getSqlSessionFactory().openSession( ExecutorType.BATCH);//开启executor
        this.personMapper = sqlSession.getMapper( PersonMapper.class );
        for(int i=0;i<10000;i++){
            Person person = new Person();
            person.setUsername( "horse" + i );
            person.setEmail( "horse@" + i + ".com" );
            this.personMapper.insertByExecutorBatch(person);
        }
        this.sqlSession.commit();
        this.sqlSession.close();
        endTime = System.currentTimeMillis();
        System.out.println( endTime - beginTime  );

    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Mybatis可以通过使用批量插入的方式来提高数据插入的效率。具体步骤如下: 1. 在Mapper.xml文件中编写批量插入的SQL语句,例如: ``` <insert id="batchInsert" parameterType="java.util.List"> insert into user (name, age) values <foreach collection="list" item="item" separator=","> (#{item.name}, #{item.age}) </foreach> </insert> ``` 2. 在Java代码中调用Mapper接口的批量插入方法,例如: ``` List<User> userList = new ArrayList<>(); // 添加多个User对象到userList中 userMapper.batchInsert(userList); ``` 3. 在Mybatis的配置文件中开启批量插入的支持,例如: ``` <configuration> <settings> <setting name="jdbc.batch_size" value="100"/> </settings> </configuration> ``` 其中,jdbc.batch_size表示每次批量插入数据量,可以根据实际情况进行调整。 以上就是使用Mybatis批量插入数据到MySQL的方法。 ### 回答2: Mybatis是一款优秀的ORM框架,通过Mybatis我们可以很方便地进行数据的CRUD操作。 在实际开发中,有时我们需要批量插入数据至MySQL数据库中,Mybatis也提供了非常方便的解决方案。 Mybatis批量插入数据MySQL的具体实现方式如下: 1. 创建一个DAO对象,用于与Mapper文件进行交互。 2. 在Mapper文件中定义一个批量插入数据的SQL语句,并使用foreach标签进行遍历。 3. 在DAO对象中调用mybatis提供的批量执行SQL语句的方法。 下面我们详细介绍一下这三个步骤的实现细节: 1. 创建一个DAO对象 创建DAO对象的过程和Mybatis普通操作数据库是相同的。在Spring框架中,我们可以通过注入SqlSession对象来操作数据库。具体如下: // 定义DAO对象 @Repository public class UserDaoImpl implements UserDao { // 注入SqlSession对象 @Autowired private SqlSession sqlSession; // 批量插入数据方法 public void batchInsert(List<User> userList) { // 调用Mapper文件中定义的SQL语句 sqlSession.insert("UserMapper.batchInsert", userList); } } 2. 定义批量插入SQL语句 在Mapper文件中定义一个批量插入的SQL语句,并使用foreach标签进行遍历。具体如下: <!-- 批量插入用户数据 --> <insert id="batchInsert" parameterType="java.util.List"> insert into user (username, age, gender) values <foreach collection="list" item="user" separator=","> (#{user.username}, #{user.age}, #{user.gender}) </foreach> </insert> 上述SQL语句中,我们使用了foreach标签进行遍历,并使用separator属性指定了每一条SQL语句之间的分隔符。 3. 调用批量执行SQL语句的方法 调用Mybatis提供的批量执行SQL语句的方法,具体如下: // 使用SqlSession批量执行SQL语句 sqlSession.flushStatements(); 注意,如果要进行批量操作,我们需要将所有SQL语句的执行结果全部缓存起来,然后一次性将缓存的数据提交至MySQL数据库中。上述代码中的flushStatements()方法就是将缓存的数据提交至MySQL数据库中。 通过以上三个步骤,我们就可以在Mybatis中完成数据批量插入操作了。此方法不仅提高了代码执行效率,而且减少了与MySQL之间的IO开销,从而有效的提高了系统的性能。 ### 回答3: Mybatis 是一款流行的 Java 持久化框架,它提供了一种简单的方式来访问和操作数据库。在大量数据插入的情况下,Mybatis批量插入功能能够显著提高插入性能。 在 Mybatis 中,批量插入数据到 MySQL 可以通过 SQL 批量执行来实现。以下是实现批量插入数据的步骤: 1. 创建一个数据源和一个 SqlSessionFactory 对象。数据源是连接数据库的关键。SqlSessionFactory 实例化后用来创建 SqlSession。 2. 创建一个 SqlSession 对象。SqlSession 是与数据库交互的主要对象。 3. 批量插入前,需要准备好要插入的数据。可以通过编写一个循环,或者使用工具类来读取数据源,把数据封装到一个对象列表中。 4. 在 Mybatis 的 Mapper XML 文件中,编写插入数据的 SQL 语句。通过使用 INSERT INTO VALUES 语法,可以实现批量插入数据。其中,VALUES 后面跟的是插入值的列表,每个列表代表一行。 5. 调用 SqlSession 的批处理方法,将插入 SQL 和数据列表传递给它。 6. 执行 SQL 批处理方法。Mybatis 会将 SQL 语句和参数封装到批处理对象中,并使用 JDBC 批量更新函数执行批量插入。 7. 最后,关闭 SqlSession 对象和数据库连接。 总之,Mybatis批量插入功能非常方便、高效,可以显著提高数据插入的性能。在实际项目中,我们可以根据具体需求选择合适的批处理方式,来实现高效的数据插入操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值