在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倍