您的位置:首页 > 数据库 > Oracle

MyBatis中的批量插入、删除(MySql、Oracle)

2015-11-19 14:18 573 查看
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/time1118/article/details/49927089

批量插入
批量插入mysql和oracle的sql会有些差别,要注意!

mysql:

<insert id="batchInsert" parameterType="java.util.List">
insert into user(username, password) values
<foreach collection="list" item="item" index="index"
separator=",">
(#{item.username},
#{item.password} )
</foreach>
</insert>

oracle:

<insert id="batchInsert" parameterType="java.util.List">
insert into user(username, password)
<foreach close=")" collection="list" item="item" index="index" open="(" separator="union">
select
#{item.username,jdbcType=VARCHAR},
#{item.password,jdbcType=VARCHAR}
from dual
</foreach>
</insert>

下面的是Oracle使用 Sequence来生成主键的批量插入写法

<insert id="batchInsert" parameterType="java.util.List">
insert into user(id, username, password)
select SEQ_USER_ID.NEXTVAL,T.* from(
<foreach collection="list" item="item" index="index"
separator="UNION">
SELECT
#{item.username,jdbcType=VARCHAR},
#{item.password,jdbcType=VARCHAR}
from dual
</foreach>
) T
</insert>

批量删除

<delete id="batchDeleteByIdList" parameterType="java.util.List">
delete from user
where id in
<foreach item="id" collection="list" open="(" separator="," close=")">
#{id}
</foreach>
</delete>

当然,也可以使用Array来替代List,修改parameterType=“array”和collection=”array”即可

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: