MyBatis插入数据后返回主键

应用场景

当用mybatis插入一条记录后,需要用这条记录的主键(或者其他唯一标识)进行下一步操作时,我们想插入完成后,立即得到该条记录的主键或其他唯一标识

代码

mapper接口

package com.fenzhichuanmei.mapper;

import com.fenzhichuanmei.pojo.SmsMessage;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

/**
 * @author Yi Dai 484201132@qq.com
 * @since 2022/3/8 14:29
 */
@Mapper
public interface SmsMessageMapper {

    int saveSmsMessage(@Param("smsMessage") SmsMessage smsMessage);

}

xml配置文件

<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.fenzhichuanmei.mapper.SmsMessageMapper">

    <insert id="saveSmsMessage" parameterType="smsMessage" useGeneratedKeys="true" keyProperty="id" keyColumn="id">
        insert into `sms_message`(`sender`, `content`, `icc_id`, `time_of_sent`, `time_of_receipt`)
            value (#{smsMessage.sender}, #{smsMessage.content}, #{smsMessage.iccId}, #{smsMessage.timeOfSent},
                   #{smsMessage.timeOfReceipt})
    </insert>

</mapper>

配置解释

keyProperty用于指定映射到实体类中的哪个字段 keyColumn指定用数据库表中的哪个列(字段)映射到keyProperty指定的实体类字段

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值