mybatis中Insert后主键返回
Posted lyn4ever
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis中Insert后主键返回相关的知识,希望对你有一定的参考价值。
1.Mapper的写法,返回的这个int是受影响的行号
int insertNewUser(User newUser);
2.xml的写法
<!--返回主键 形式1 -->
<insert id="saveReturnPK1" parameterType="cn.lyn4ever.bean.User" useGeneratedKeys="true" keyProperty="id">
INSERT INTO `test`.`tb_user`(`username`, age) VALUES(#username, #age)
</insert>
<!-- 返回主键 形式2 -->
<insert id="saveReturnPK2" parameterType="cn.lyn4ever.bean.User">
<selectKey keyProperty="id" resultType="int" order="AFTER">
SELECT LAST_INSERT_ID()
</selectKey>
INSERT INTO `test`.`tb_user`(`username`, age) VALUES(#username, #age)
</insert>
3.如何拿到我们刚插入的这个类呢?还是用我们之前插入时的那个newUser,mybatis会给它加上返回的主键的,Mapper方法中返回的那个int只是受影响的行号而已,此时,只会返回0或1
newUser.getId(); 这个不再是空的了
以上是关于mybatis中Insert后主键返回的主要内容,如果未能解决你的问题,请参考以下文章
mybatis 通用mapper.xml中 insert 方法不是自增主键怎么返回