景区网站如何建设,什么是管理,品牌网站建设方,站长之家源码主键回填其实是一个非常常见的需求#xff0c;特别是在数据添加的过程中#xff0c;我们经常需要添加完数据之后#xff0c;需要获取刚刚添加的数据 id#xff0c;无论是 Jdbc 还是各种各样的数据库框架都对此提供了相关的支持#xff0c;本文我就来和和大家分享下数据库主…主键回填其实是一个非常常见的需求特别是在数据添加的过程中我们经常需要添加完数据之后需要获取刚刚添加的数据 id无论是 Jdbc 还是各种各样的数据库框架都对此提供了相关的支持本文我就来和和大家分享下数据库主键回填在 MyBatis 中的两种实现思路。
框架来源于我们学过的基础知识主键回填实际上是一个在 JDBC 中就被支持的写法有的小伙伴可能不知道这一点因此这里我先来说说在 JDBC 中如何实现主键回填。
JDBC 中实现主键回填其实非常容易主要是在构造 PreparedStatement 时指定需要主键回填然后在插入成功后查询刚刚插入数据的 id 示例代码如下
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 中对此需求提供了两种不同的实现方案下面分别来看。
框架写法
一般情况下主键有两种生成方式
主键自增长自定义主键一般可以使用UUID或者类UUID
如果是第二种主键一般是在Java代码中生成然后传入数据库执行插入操作如果是第一个主键自增长此时Java 可能需要知道数据添加成功后的主键。
MyBatis 的基本用法就无需多说了这也不是本文的重点我们还是来看看 MyBatis 中主键回填的两种不同实现方式吧
方式一
第一种方式比较简单也是比较推荐的一种实现方式
insert insert into t_book (b_name,author) values (#{name},#{author});
/insert这种方式比较简单就是在插入节点上添加 useGeneratedKeys 属性同时设置接收回传主键的属性。配置完成后我们执行一个插入操作插入时传入一个对象插入完成后这个对象的 id 就会被自动赋值值就是刚刚插入成功的id。
推荐大家使用这种方式原因很简单这种方式实现简便省事。
方式二
第二种方式则是利用MySQL自带的 last_insert_id() 函数查询刚刚插入的id示例代码如下
language-javainsert selectKey keyPropertyid resultTypejava.lang.IntegerSELECT LAST_INSERT_ID()/selectKeyinsert into t_book (b_name,author) values (#{name},#{author});
/insert这种方式是在 insert 节点中添加 selectKey 来实现主键回填实际上这种方式的功能更加丰富因为 selectKey 节点中的 SQL 我们既可以在插入之前执行也可以在插入之后执行通过设置节点的 Order 属性为 AFTER 或者 BEFORE 可以实现具体什么时候执行还是要看具体的需求如果是做主键回填我们当然需要在插入 SQL 执行之后执行 selectKey 节点中的 SQL。
注意第二种方式一样也要通过设置 keyProperty 来指定将查询到的数据绑定到哪个属性上。