Oralce+Mybatis以list集合批量插入数据

这是一个mapper接口,Users_Roles是一个实体类

@Mapper
public interface FPYHMapper {
    void usersAddAll(ArrayList<Users_Roles> list);
}

mapper.xml 中的数据

 <!--批量添加信息-->
    <insert id="usersAddAll" parameterType="list">
        insert into users_roles(users_id,roles_id)
        <foreach collection="list" item="item" index="index" separator="UNION ALL">
            select #{item.users_id,jdbcType=NULL},#{item.roles_id,jdbcType=NULL} from dual
        </foreach>
    </insert>

"UNION ALL"作用:合并结果集
根据上下配置文件,需要注意三个地方:
(1)需要取掉values

(2)separator属性值改为UNION ALL。因为在oracle中用insert into xxx values (xxx,xxx),(xxx,xxx) 这种语法是通不过的

(3)foreach标签中需要取掉括号,加入select …from dual.

<insert id="usersAddAll" parameterType="list" useGeneratedKeys="false">
 // useGeneratedKeys="false" 有人说加入这个也能解决批量插入,我没试过
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值