Mybatis批量插入并且返回对应的ID

本文介绍了如何在MyBatis中通过useGeneratedKeys和keyProperty属性插入数据时获取数据库自增主键,特别关注了如何设置keyProperty以对应list对象的id属性,并提供了一个实际操作示例。
摘要由CSDN通过智能技术生成

首先设置属性:useGeneratedKeys,keyProperty

useGeneratedKeys:(仅适用于 insert 和 update)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 
	方法来取出由数据库内部生成的主键。
	(比如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的自动递增字段),默认值:false。
keyProperty:(仅适用于 insert 和 update)指定能够唯一识别对象的属性。
	MyBatis 会使用 getGeneratedKeys 的返回值或 insert 语句的 selectKey 子元素设置它的值,
	默认值:未设置(unset)。如果生成列不止一个,可以用逗号分隔多个属性名称。

我的使用:

    int addCustomizedData(@Param("a") Integer a, @Param("b") Integer b, @Param("list") List<Bean> list);

<insert id="addCustomizedData" useGeneratedKeys="true" keyProperty="list.id">
        INSERT INTO tbl_ext (
            name, 
            age
            ) VALUES
        <foreach collection="list" item="item" index="index" separator=",">
            <trim prefix=" (" suffix=")" suffixOverrides=",">
                #{name}, 
                #{age}
            </trim>
        </foreach>
    </insert>
注意:keyProperty="list.id"。id为list中对象中的id属性。我定义的mapper中有多个参数,如果只指定id的话,会报错。
如果只有一个list参数,那直接使用keyProperty="id" 也是可以。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值