使用mybatis框架,LAST_INSERT_ID()不能返回主键id的解决方法

记录一下,免得以后忘记
这里就直接贴上代码了,注解很详细
xml代码:

<insert id="insertEquipment" parameterType="EquipmentInfo">
        <!--
            parameterType是实体类对象,不是数据类型
            将insert插入的数据的主键返回到EquipmentInfo对象中;
            select last_insert_id():得到刚刚添加进去记录的主键值,必须自增主键;
            selectKey  会将 SELECT LAST_INSERT_ID()的结果放入到传入的model的主键里面,
            keyProperty 对应的model中的主键的属性名,这里是 EquipmentInfo 中的equipmentId,因为它跟数据库的主键对应
            order AFTER 表示 SELECT LAST_INSERT_ID() 在insert执行之后执行,多用与自增主键,相对于insert语句
                  BEFORE 表示 SELECT LAST_INSERT_ID() 在insert执行之前执行,这样的话就拿不到主键了,
                        这种适合那种主键不是自增的类型
            resultType 主键数据类型
        -->
        insert into equipment_info(equipment_num) values (#{equipmentNum})
        <selectKey keyProperty="equipmentId" order="AFTER" resultType="int">
            select LAST_INSERT_ID()
        </selectKey>
    </insert>

mapper代码:

public int insertEquipment(EquipmentInfo equipmentInfo);

这里的maper中返回的是添加成功后,数据库的影响行数,不是主键id,须注意

int equipmentId = new EquipmentInfo().getEquipmentId();

主键id需要通过get方法获取

注意事项:
1、parameterType传入的是实体类对象,不能是数据类型(本人改为实体类型,就能获取主键了,不知道是否必须是实体类,暂未弄明白,须继续学习)。
2、对应的mapper文件中,参数不能用@Param()注解
3、对应表必须主键自增

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值