Mybatis实现添加记录时返回主键值

方法一: Mybatis 配置文件 useGeneratedKeys 参数

Mybatis 配置文件 useGeneratedKeys 参数只针对 insert 语句生效,默认为 false。当设置为 true 时,表示如果插入的表以自增列为主键,则允许 JDBC 支持自动生成主键,并可将自动生成的主键返回

Mybatis实现添加记录时返回主键值_第1张图片

DAO 调用 aboutUsInfo 后,aboutUsInfo 对象参数中就保存了新增的 id 属性了。

但是,如果是 Oracle 这样不支持自增主键列的数据库,如果把useGeneratedKeys 参数配置为 true,在插入多条数据时则可能会出现 ORA-00933: SQL command not properly ended 
这样的错误。这时,可以将 useGeneratedKeys 配置为 false,或者为了保证兼容性,使用 mybatis 提供的 selectKey 手动提供类似自增序列的效果。

Mybatis实现添加记录时返回主键值_第2张图片

方法二: 使用mybatis注解@Options实现添加记录时返回主键值

需要在执行添加操作之后,直接访问对象的主键字段属性即可取得对应值。

最后需要说明:在mybatis中使用注解实现添加记录时,可以使用@Insert或者@InsertProvider 2个注解,都可以使用@Options注解获取新添加记录的自增长主键字段值。

Mybatis实现添加记录时返回主键值_第3张图片

 

你可能感兴趣的:(Mybatis)