摘要
Hibernate中获取新插入记录的对象id非常容易,通过其持久化对象就能完成。而Mybatis中有点复杂,本文转载了一篇文章,讲述mybatis中获取插入记录的自增长id,经测试在mysql中有效,其他数据库未知。
需求
使用MyBatis往MySQL数据库中插入一条记录后,需要返回该条记录的自增主键值。
方法
下面说两种方法,MyBatis+MySQL 返回插入记录的主键ID:
第一种:
<insert id="insert" parameterType="Spares"
useGeneratedKeys="true" keyProperty="id">
insert into system(name) values(#{name})
</insert>
第二种:
<insert id="insert" parameterType="cn.***.beans.LogObject" >
<selectKey resultType="java.lang.Integer" order="BEFORE" keyProperty="id">
SELECT LOGS_SEQ.nextval AS ID FROM DUAL
</selectKey>
INSERT INTO S_T_LOGS (
ID,
USER_ID,
USER_NAME,
USER_IP,
OPERATION_TIME,
DESCRIPTION,
RESOURCE_ID)
VALUES (
#{id},
#{userId},
#{userName},
#{userIp},
#{operationTime},
#{description},
#{resourceId})
</insert>
总结
这两种写法都可以,但有两点一定要注意:
1)Mybatis Mapper 文件中,“useGeneratedKeys”和“keyProperty”必须添加,keyProperty=”id” ,这个id必须是实体的id,而不是数据表的主键id,否则,得不到正确的返回结果;
2)接收返回值时候,必须用实体的get属性,而不能定义变量,否则,接收不到正确的返回结果:即必须用user.getId()来接收。