博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 批量插入与单条插入 的效率比较
阅读量:5153 次
发布时间:2019-06-13

本文共 1246 字,大约阅读时间需要 4 分钟。

1、数据插入性能(单个插入和批量插入)
[java]   
 
 
  1. public class Test {  
  2.   
  3.     private Long id;  
  4.   
  5.     private String test;  
  6.   
  7.     public Long getId() {  
  8.         return id;  
  9.     }  
  10.   
  11.     public void setId(Long id) {  
  12.         this.id = id;  
  13.     }  
  14.   
  15.     public String getTest() {  
  16.         return test;  
  17.     }  
  18.   
  19.     public void setTest(String test) {  
  20.         this.test = test;  
  21.     }  
  22. }  

mapper.xml文件

 

[html]   
 
 
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >  
  3. <mapper namespace="com.astrospace.test.mapper.TestMapper" >  
  4.     <resultMap id="test" type="com.astrospace.test.dmo.Test" >  
  5.         <id property="id" column="ID"/>  
  6.         <result property="test" column="TEST" />  
  7.     </resultMap>  
  8.   
  9.     <insert id="add" parameterType="com.astrospace.test.dmo.Test">  
  10.         INSERT INTO TEST(ID,TEST) VALUES(#{id},#{test});  
  11.     </insert>  
  12.   
  13.     <insert id="batchAdd" parameterType="java.util.List">  
  14.         INSERT INTO TEST(ID,TEST)  
  15.         VALUES  
  16.         <foreach collection="list" item="item" index="index" separator="," >  
  17.             (#{item.id},#{item.test})  
  18.         </foreach>  
  19.     </insert>  
  20.   
  21. </mapper>  

 

 

调用add和batchAdd方法即可。

不同数据量5次,结果如下:

单独插入50000条数据平均耗时:233748ms

批量插入50000条数据平均耗时:2590ms
对比:效率差50倍
单独插入10000条数据平均耗时:22036ms
批量插入10000条数据平均耗时:3330ms
对比:效率差6倍
单独插入1000条数据平均耗时:3122ms
批量插入1000条数据平均耗时:374ms
对比:效率差8倍

数据越多,效率愈发明显。

转载于:https://www.cnblogs.com/toSeeMyDream/p/6846505.html

你可能感兴趣的文章
52. N-Queens II
查看>>
CS231n assignment2 Q3 Dropout
查看>>
Vue.js前后端同构方案之准备篇——代码优化
查看>>
SPOJ DIVISION - Divisiblity by 3
查看>>
关于用C#实现宽带的连接
查看>>
codevs 3369 膜拜
查看>>
Python网络编程笔记一
查看>>
配置Sublime Text2的python运行环境(Sublime Text 3也类似)
查看>>
SQL (FMDB)
查看>>
eclipse 常用设置(一)
查看>>
springmvc 注解总结
查看>>
FTL指令常用标签及语法
查看>>
Linux查看系统信息的一些命令及查看已安装软件包的命令
查看>>
Asp.Net入门(一)
查看>>
Day 07 数据类型的内置方法(列表\字典\元祖\集合),深浅拷贝
查看>>
PAT甲题题解-1119. Pre- and Post-order Traversals (30)-(根据前序、后序求中序)
查看>>
小型web项目的模块化(转)
查看>>
HDU 2756 & UVA 11572 Unique Snowflakes
查看>>
JavaScript教程:浅析JS运行机制
查看>>
JavaScript基础篇
查看>>