怎么在MyBatis中实现主键回填?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
代码如下:
public int 插入(Person 人),{ Connection 才能;con =,空; PreparedStatement 才能;ps =,空; ResultSet 才能;rs =,空; 时间=con 才能;DBUtils.getConnection (); ps 才能=,con.prepareStatement (“INSERT  INTO 人(用户名、密码,钱),值(?,?,?)“,,PreparedStatement.RETURN_GENERATED_KEYS); ps.setObject才能(1,person.getUsername ()); ps.setObject才能(2,person.getPassword ()); ps.setObject才能(3,person.getMoney ()); int 才能;小姐:=,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中主键回填的两种不同实现方式吧!
<强>方式一强>
第一种方式比较简单,也是松哥推荐的一种实现方式:
& lt; insert id=癷nsertBook", useGeneratedKeys=皌rue", keyProperty=癷d"比; insert 才能;into  t_book (作者b_name), values (# {name}, #{作者}); & lt;/insert>
这种方式比较简单,就是在插入节点上添加useGeneratedKeys属性,同时设置接收回传主键的属性。配置完成后,我们执行一个插入操作,插入时传入一个对象,插入完成后,这个对象的id就会被自动赋值,值就是刚刚插入成功的id。
推荐大家使用这种方式,原因很简单,这种方式实现简便省事。
<强>方式二强>
第二种方式则是利用MySQL自带的last_insert_id()函数查询刚刚插入的id,示例代码如下:
& lt; insert id=癷nsertBook"比; & lt;才能selectKey keyProperty=癷d", resultType=癹ava.lang.Integer"比; ,,,SELECT LAST_INSERT_ID () & lt;才能/selectKey> insert 才能;into  t_book (作者b_name), values (# {name}, #{作者}); & lt;/insert>
这种方式是在插入节点中添加selectKey来实现主键回填,实际上这种方式的功能更加丰富,因为selectKey节点中的SQL我们既可以在插入之前执行,也可以在插入之后执行(通过设置节点的订单属性为之后或之前者可以实现),具体什么时候执行,还是要看具体的需求,如果是做主键回填,我们当然需要在插入SQL执行之后执行selectKey节点中的SQL。
看完上述内容,你们掌握怎么在MyBatis中实现主键回填的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!