mybatis执行insert语句时返回实体携带自增主键

在MyBatis中,通过设置useGeneratedKeys和keyProperty属性,可以在执行插入操作后,使返回的实体对象包含生成的自增主键。parameterType定义输入参数类型,keyColumn指定自增主键列,keyProperty设定返回值映射的属性。当数据库支持时,useGeneratedKeys启用获取自增键功能。

在执行insert语句后,如果希望直接返回的实体类携带了生成的自增id,就需要在sql语句中指定useGeneratedKeys和keyProperty属性值。

<!-- 
		所有数据库通用,插入成功返回最近一次插入的id
		它会将id直接赋值到对应的实体当中
			YyghDdxx yyghddxx = new YyghDdxx();
            OrderMapper.insert(YyghDdxx record);
			int pk = yyghddxx.getId(); // 这就是我们的主键id
 -->
<insert id="insert" parameterType="com.order.model.YyghDdxx" useGeneratedKeys="true"  
keyColumn="ID" keyProperty="id">
  insert into Yygh_Ddxx(ID,name, age,phonenumber) 
  values(#{id,jdbcType=int}, #{name,jdbcType=VARCHAR},{age,jdbcType=int},{phonenumber,jdbcType=VARCHAR})
</insert>

一、insert  属性详解

   parameterType ,入参的全限定类名或类型别名

   keyColumn ,设置数据表自动生成的主键名。对特定数据库(如PostgreSQL),若自动生成的主键不是第一个字段则必须设置

   keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中

   useGeneratedKeys ,取值范围true|false(默认值),设置是否使用JDBC

<think>我们正在处理用户关于MyBatis插入返回主键的问题。根据引用[1][2][3],我们可以看到在MyBatis中有两种主要方式来实现这个需求:使用`@SelectKey`注解(注解方式)或使用`<selectKey>`标签(XML方式)。两种方式的核心都是执行一个数据库函数来获取最后插入的自ID。 用户的需求是:在执行语句返回主键。 根据引用内容,我们可以总结如下: 1. 对于MySQL数据库,常用的函数是`LAST_INSERT_ID()`(引用[1][2])或`@@IDENTITY`(引用[3])。 2. 使用`<selectKey>`标签,需要设置`order`属性为`AFTER`(示在insert语句之后执行),`keyProperty`指定将返回设置到参数的哪个属性中,`resultType`指定返回的类型。 3. 在注解方式中,使用`@SelectKey`注解,并设置`before=false`示在insert之后执行。 因此,我们可以提供两种方式的示例: 方式一:XML映射文件方式 ```xml <insert id="insertUser" parameterType="User"> <!-- 在插入之后,获取自主键并设置到参数的id属性中 --> <selectKey keyProperty="id" resultType="long" order="AFTER"> SELECT LAST_INSERT_ID() </selectKey> INSERT INTO user (username, password) VALUES (#{username}, #{password}) </insert> ``` 方式二:注解方式(在Mapper接口的方法上使用) ```java @Insert("INSERT INTO user (username, password) VALUES (#{username}, #{password})") @SelectKey(statement = "SELECT LAST_INSERT_ID()", keyProperty = "id", before = false, resultType = long.class) int insertUser(User user); ``` 注意:在调用insert方法后,传入的参数对象(例如User对象)的id属性就会被自动赋为自主键。 另外,引用[3]中使用了`SELECT @@IDENTITY`,但需要注意,`@@IDENTITY`和`LAST_INSERT_ID()`在MySQL中都可以获取自ID,但`LAST_INSERT_ID()`是基于当前连接的,不会受到其他连接的影响,更安全。而`@@IDENTITY`是获取当前数据库最后一次插入的自ID,如果有其他连接插入了数据,可能会获取到错误的ID。所以推荐使用`LAST_INSERT_ID()`。 因此,我们给出推荐做法:使用`LAST_INSERT_ID()`。 引用[1][2][3]都提供了类似的方法,我们可以参考。 最后,我们还需要注意,不同的数据库获取自主键的方式可能不同,例如Oracle需要使用序列。但用户明确提到MySQL,所以这里只考虑MySQL。 根据以上分析,我们给出回答。</think>### MyBatis 插入操作后返回主键的方法 在 MyBatis 中获取插入操作后的自主键,主要通过 `<selectKey>` 标签或 `@SelectKey` 注解实现。以下是两种常用方法: #### 方法一:XML 映射文件配置(推荐) ```xml <insert id="insertUser" parameterType="User"> <!-- 核心配置:插入后获取自ID --> <selectKey keyProperty="id" <!-- 将返回绑定到实体类的id属性 --> order="AFTER" <!-- 在INSERT语句执行执行 --> resultType="java.lang.Long" statementType="PREPARED"> SELECT LAST_INSERT_ID() <!-- MySQL函数获取最新自ID --> </selectKey> INSERT INTO user (name, email) VALUES (#{name}, #{email}) </insert> ``` **调用方式**: ```java User user = new User("张三", "zhangsan@example.com"); mapper.insertUser(user); // 插入后自动填充主键 System.out.println("生成的主键ID:" + user.getId()); // 直接获取实体对象的id ``` #### 方法二:注解方式配置 ```java @Insert("INSERT INTO user (name, email) VALUES (#{name}, #{email})") @SelectKey( statement = "SELECT LAST_INSERT_ID()", keyProperty = "id", // 绑定到实体类的id属性 before = false, // 在INSERT之后执行 resultType = Long.class ) int insertUser(User user); ``` #### 关键配置说明: 1. **`keyProperty`** 指定实体类中接收主键的属性名(如 `id`) 2. **`order`** - `AFTER`:适用于 MySQL主键插入后获取) - `BEFORE`:适用于 Oracle 序列(插入前获取) 3. **数据库函数** - MySQL:`SELECT LAST_INSERT_ID()` (确保同连接内立即获取,不受其他会话影响[^2][^3]) - SQL Server:`SELECT SCOPE_IDENTITY()` - PostgreSQL:`RETURNING id` > ⚠️ **注意事项** > - 需确保数据库主键设置为 `AUTO_INCREMENT`(MySQL) > - 批量插入 `LAST_INSERT_ID()` 仅返回第一条数据的ID > - 高并发场景建议使用 `@@IDENTITY`(但需注意触发器影响)[^3] --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值