Mybatis在insert操作时返回主键

时间:2022-06-01 19:43:39

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

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

如图:

Mybatis在insert操作时返回主键

属性详解:

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

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

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

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

测试代码:

Mybatis在insert操作时返回主键

所得结果:

Mybatis在insert操作时返回主键

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

Mybatis在insert操作时返回主键

原来,是我理解错了!

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

如图

Mybatis在insert操作时返回主键

所得结果:

Mybatis在insert操作时返回主键

ok,大功告成。

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