博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据库--MyBatis的(insert,update,delete)三种批量操作
阅读量:5095 次
发布时间:2019-06-13

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

转自:http://blog.csdn.net/starywx/article/details/23268465

前段时间由于项目赶期没顾上开发过程中的性能问题,现对部分代码进行优化的过程中发现在数据量大的情况下对数据的操作反应似乎有些慢,就想到对数据库DML操作的时候进行批量操作。说道这里也想到自己在一次面试的时候别问道过批量操作数据的问题。现对运用说明记录如下:批量插入insert方法一:
SELECT LAST_INSERT_ID()
INSERT INTO sourcedoc (sdate, sweek, roomno, daysched, nightsched, adminsched, vacationsched, programdept, programname )values
(#{item.sdate},#{item.sweek},#{item.roomno},#{item.daysched},#{item.nightsched},#{item.adminsched},#{item.vacationsched},#{item.programdept},#{item.programname} )
方法二:
insert into table1(sdate,sweek,roomno,daysched,nightsched,adminsched,vacationsched,programdept,programname)
select #{item.sdate,jdbcType=VARCHAR},#{item.sweek,jdbcType=VARCHAR},#{item.roomno,jdbcType=VARCHAR},#{item.nightsched,jdbcType=VARCHAR},#{item.adminsched,jdbcType=VARCHAR},#{item.vacationsched,jdbcType=VARCHAR},#{item.programdept,jdbcType=VARCHAR},0,0,#{item.programname,jdbcType=VARCHAR} from dual
可以考虑用union all来实现批量插入。例如:insert into XX_TABLE(XX,XX,XX)select 'xx','xx','xx' union all select 'xx','xx','xx' union all select 'xx','xx','xx' ...先拼装好语句再动态传入insert into XX_TABLE(XX,XX,XX)后面部分 批量删除(delete)
DELETE FROM LD_USER WHERE ID in
#{item}
批量修改(update)
update orders set state = '0' where no in
#{nos}
MyBatis中in子句 in 参数 使用方法1.只有一个参数 参数的类型要声明为List或Array Sql配置如下: 2.多个参数 首先要将多个参数写入同一个map,将map作为一个参数传入mapper Sql配置如下: 批量数据操作的体会 MyBatis的前身就是著名的Ibatis,不知何故脱离了Apache改名为MyBatis。 MyBatis所说是轻量级的ORM框架,在网上看过一个测试报告,感觉相比于Hibernate来说,优势并不明显。下面说一下比较有趣的现象,根据MyBatis的官方文档,在获得sqlSession时,它有为批量更新而专门准备的:session = sessionFactory.openSession();//用于普通updatesession = sessionFactory.openSession(ExecutorType.BATCH, true);//用于批量update 一般来说,对MYSQL数据库批量操作时速度取决于,是为每一个处理分别建立一个连接,还是为这一批处理一共建立一个连接。按MyBatis的手册说明,选择ExecutorType.BATCH意味着,获得的sqlSession会批量执行所有更新语句。不过我测试了一下,批量插入1000条数据,发觉ExecutorType.BATCH方式的效率居然比普通的方式差很多。我测试用的Mapper中的insert配置如下,再用for循环插入1000条记录:
insert into student (id, name, sex,address, telephone, t_id)values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR},#{sex,jdbcType=VARCHAR},#{address,jdbcType=VARCHAR}, #{telephone,jdbcType=VARCHAR}, #{tId,jdbcType=INTEGER})
关于数据库批量插入时sql语句级的优化,我特意测试了两种方式,在StudentMapper中配置了两种insert模式。第一种对应insert value1,insert value2,,,,;第二种对应insert values (value1, value2,....)。发现后者果然比前者快很多啊。下面是两种insert模式,及测试结果对应图:
insert into student (
) values
(null,#{item.name},#{item.sex},#{item.address},#{item.telephone},#{item.tId})
insert into student (id, name, sex,address, telephone, t_id)values (#{id,jdbcType=INTEGER}, #{name,jdbcType=VARCHAR},#{sex,jdbcType=VARCHAR},#{address,jdbcType=VARCHAR}, #{telephone,jdbcType=VARCHAR}, #{tId,jdbcType=INTEGER})

  

转载于:https://www.cnblogs.com/YLQBL/p/7815989.html

你可能感兴趣的文章
(转)Android之发送短信的两种方式
查看>>
使用vue脚手架搭建项目
查看>>
Java基础之ArrayList与LinkedList、Vector,以及HashMap与HashTable的区别
查看>>
python第九天课程:遇到了金角大王
查看>>
字符串处理
查看>>
ECharts(Enterprise Charts 商业产品图表库)初识
查看>>
LeetCode Factorial Trailing Zeroes (阶乘后缀零)
查看>>
hdu 5402 Travelling Salesman Problem (技巧,未写完)
查看>>
[AIR] 获取U盘,打开U盘
查看>>
HtmlUnitDriver 网页内容动态抓取
查看>>
ad logon hour
查看>>
获得进程可执行文件的路径: GetModuleFileNameEx, GetProcessImageFileName, QueryFullProcessImageName...
查看>>
证件照(1寸2寸)拍摄处理知识汇总
查看>>
罗马数字与阿拉伯数字转换
查看>>
Eclipse 反编译之 JadClipse
查看>>
asp.net 获取IP地理位置的几个主要接口
查看>>
Python入门-函数
查看>>
[HDU5727]Necklace(二分图最大匹配,枚举)
查看>>
距离公式汇总以及Python实现
查看>>
设计模式之装饰者模式
查看>>