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

本文共 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

你可能感兴趣的文章
【R】shiny界面
查看>>
gnl总结(#,%,$)
查看>>
Java 多线程编程两个简单的例子
查看>>
PB+MS SQL+触发器必须指出
查看>>
UVa 340 Master-Mind Hints
查看>>
Linux 的 Shell
查看>>
开源一个动态解析protobuf的工具
查看>>
hadoop学习笔记(四)——eclipse+maven+hadoop2.5.2源代码
查看>>
微信公众平台开发(一)——配置、请求
查看>>
基于android的实时音频频谱仪
查看>>
Atitit.进程管理常用api
查看>>
如何避免javascript中的冲突
查看>>
linux下一个Oracle11g RAC建立(五岁以下儿童)
查看>>
spark on hive 配置hive的metastore为mysql
查看>>
http://www.cnblogs.com/TankXiao/archive/2012/02/06/2337728.html
查看>>
史上最全的CSS hack方式一览
查看>>
性能测试工具
查看>>
联想THINKPAD E40的快捷键怎么关闭?哪些F1 F2 F3的键我需要用到 但是每次都按FN 太烦人了...
查看>>
如何同时激活两个不同版本的MyEclipse 【MyEclipse2013和MyEclipse2014同时激活】
查看>>
jQuery改造插件,添加回调函数
查看>>