mybatis單個插入和批量插入的簡單比較


在J2EE項目中,mybatis作為主流持久層框架,許多知識值得我們去鑽研學習,今天,記錄一下數據插入性能(單個插入和批量插入)。

一,測試對象

public class Test {

    private Long id;

    private String test;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getTest() {
        return test;
    }

    public void setTest(String test) {
        this.test = test;
    }
}

二、對應的mapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.astrospace.test.mapper.TestMapper" >
    <resultMap id="test" type="com.astrospace.test.dmo.Test" >
        <id property="id" column="ID"/>
        <result property="test" column="TEST" />
    </resultMap>

    <insert id="add" parameterType="com.astrospace.test.dmo.Test">
        INSERT INTO TEST(ID,TEST) VALUES(#{id},#{test});
    </insert>

    <insert id="batchAdd" parameterType="java.util.List">
        INSERT INTO TEST(ID,TEST)
        VALUES
        <foreach collection="list" item="item" index="index" separator="," >
            (#{item.id},#{item.test})
        </foreach>
    </insert>

</mapper>

調用邏輯這里不做敘述了,認為調用add和batchAdd方法即可。

不同數據量測試5次,結果如下:

單獨插入50000條數據平均耗時:233748ms
批量插入50000條數據平均耗時:2590ms
對比:效率差50倍
單獨插入10000條數據平均耗時:22036ms
批量插入10000條數據平均耗時:3330ms
對比:效率差6倍
單獨插入1000條數據平均耗時:3122ms
批量插入1000條數據平均耗時:374ms
對比:效率差8倍


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM