要做批量插入数据库,首先得知道该数据库对批量插入所支持的语法。每个数据库批量插入的语法都不一样,
我介绍两种。
MySQL:1、INSERTINTO TABLE_NAME(ID,NAME)VALUES(1,'张三'),(2,'李四')
2、INSERT INTO TABLE_NAME(ID,NAME)VALUES(1,'张三');
INSERT INTOTABLE_NAME(ID,NAME)VALUES(2,'李四')
Oracle:1、INSERTINTO TABLE_NAME (ID,NAME) (SELECT 1,'张三' from dual) union all (SELECT 2,'李四'from dual)
2、INSERT INTO TABLE_NAME (ID,NAME) VALUES(1,'张三');
INSERT INTOTABLE_NAME(ID,NAME)VALUES(2,'李四')
4条SQL都是数据库支持的写法。
两者的第二种是不推荐的写法,因为不管效率还是可读性上都远差于第一种 。当然,还有更重要的一点,Mybatis不支持第二种写法,
因为mybatis的一个事务只支持一条SQL 所以,Mybatis里写法只能取两者的第一种,代码如下 :
|
MySQL |
Java代码: <select id="batchSave" parameterType="java.util.List"> INSERT INTO TABLE_NAME(ID,NAME) VALUES <foreach collection="list" item="itm" separator=","> (#{itm.id},#{itm.name}) </foreach> </select> |
|
ORACLE |
Java代码: <select id="batchSave" parameterType="java.util.List"> INSERT INTO TABLE_NAME(ID,NAME) <foreach collection="list" item="itm" separator="union all"> (SELECT #{itm.id},#{itm.name} FROM DUAL) </foreach> </select>
|
本文介绍了如何使用MySQL和Oracle数据库进行批量数据插入的方法,并提供了MyBatis环境下对应的XML配置示例。
1万+

被折叠的 条评论
为什么被折叠?



