mybatis主键回填mysql_Mybatis中主键回填的多种写法

本文介绍了在MyBatis中实现主键回填的两种方法:原生JDBC方式,以及MyBatis特有的useGeneratedKeys和selectKey配置。通过设置PreparedStatement参数和使用last_insert_id()函数,可以在插入数据后自动获取生成的主键ID。
摘要由CSDN通过智能技术生成

#### Mybatis中主键回填的多种写法

主键回填其实是一个非常常见的需求,特别是在数据添加的过程中,我们经常需要添加完数据之后,需要获取刚刚添加的数据 id,无论是 Jdbc 还是各种各样的数据库框架都对此提供了相关的支持,本文我就来和和大家分享下数据库主键回填在 MyBatis 中的两种实现思路。

##### 原生写法

框架来源于我们学过的基础知识,主键回填实际上是一个在 JDBC 中就被支持的写法,有的小伙伴可能不知道这一点,因此这里我先来说说在 JDBC 中如何实现主键回填。

JDBC 中实现主键回填其实非常容易,主要是在构造 PreparedStatement 时指定需要主键回填,然后在插入成功后,查询刚刚插入数据的 id ,示例代码如下:

```java

public int insert(Person person) {

Connection con = null;

PreparedStatement ps = null;

ResultSet rs = null;

con = DBUtils.getConnection();

ps = con.prepareStatement("INSERT INTO person(username,password,money) VALUES(?,?,?)", PreparedStatement.RETURN_GENERATED_KEYS);

ps.setObject(1, person.getUsername());

ps.setObject(2, person.getPassword());

ps.setObject(3, person.getMoney());

int i = ps.executeUpdate();

rs = ps.getGeneratedKeys();

int id = -1;

if (rs.next()) {

id = rs.getInt(1);

}

return id;

}

```

和普通的插入 SQL 不同之处主要体现在两个地方:

第一个是构造 PreparedStatement 时,多了一个参数,指定了需要主键回填。

在更新操作执行完成之后,调用 getGeneratedKeys ,然后又会获取到一个 ResultSet 对象,从这个游标集中就可以获取到刚刚插入数据的id。

这个是原生的写法,在 MyBatis 中,对此需求提供了两种不同的实现方案,下面分别来看。

##### 第一种方式比较简单

```java

insert into t_book (b_name,author) values (#{name},#{author});

```

这种方式比较简单,就是在插入节点上添加 useGeneratedKeys 属性,同时设置接收回传主键的属性。配置完成后,我们执行一个插入操作,插入时传入一个对象,插入完成后,这个对象的 id 就会被自动赋值,值就是刚刚插入成功的id。

##### 第二种方式则是利用MySQL自带的 last_insert_id() 函数查询刚刚插入的id,示例代码如下:

```java

SELECT LAST_INSERT_ID()

insert into t_book (b_name,author) values (#{name},#{author});

```

这种方式是在 insert 节点中添加 selectKey 来实现主键回填,实际上这种方式的功能更加丰富,因为 selectKey 节点中的 SQL 我们既可以在插入之前执行,也可以在插入之后执行(通过设置节点的 Order 属性为 AFTER 或者 BEFORE 可以实现),具体什么时候执行,还是要看具体的需求,如果是做主键回填,我们当然需要在插入 SQL 执行之后执行 selectKey 节点中的 SQL。

注意第二种方式一样也要通过设置 keyProperty 来指定将查询到的数据绑定到哪个属性上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值