码迷,mamicode.com
首页 > 其他好文 > 详细

Mybatis在insert操作时返回主键

时间:2016-08-01 01:44:27      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:

今天在写项目的时候,遇到一个需求,就是在像数据库插入数据的时候,要保留插入数据的主键,以便后续进行级联时,可以将该主键作为另张表的外键。

但是在正常情况下我们使用插入语句返回的是int型,含义是影响该表数据的条数。但是这时候我们想要的得到的却是主键,这时候就可以对mybatis文件进行配置

如图:

技术分享

属性详解:

parameterType ,入参的全限定类名或类型别名

useGeneratedKeys ,取值范围true|false(默认值), 设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中。MySQL和 SQLServer执行auto-generated key field,因此当数据库设置好自增长主键后,可通过JDBC的getGeneratedKeys方法获取。但像Oralce等不支持auto- generated key field的数据库就不能用这种方法获取主键了

keyProperty ,默认值unset,用于设置getGeneratedKeys方法或selectKey子元素返回值将赋值到领域模型的哪个属性中

 

这时候我们住需要添加这三个属性即可完成配置

测试代码:

技术分享

所得结果:

技术分享

咦!为什么返回的还是1呢?数据库中显示的值返回的应该是26才对昂。

技术分享

 

原来,是我理解错了!

当执行完insert()方法后,Mybatis会自动将返回的主键值赋值给属性Id,然后我们就可以这样获取到属性值:UserCourse.getId();

如图

技术分享

 

所得结果:

技术分享

 

ok,大功告成。

总结:对Mybatis的使用还是不够。还有很多很多的东西需要去理解,以后还是多看看文档

 

Mybatis在insert操作时返回主键

标签:

原文地址:http://www.cnblogs.com/boycelee/p/5724440.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!