详解mysql插入数据后返回自增ID的七种方法


当前第2页 返回上一页

SelectKey 在Mybatis中是为了解决 Insert 数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。

不管 SelectKey 有多好,尽量不要遇到这种情况吧,毕竟很麻烦。

SelectKey 需要注意 order 属性:

  • Mysql 一类支持自动增长类型的数据库中,order 需要设置为 after 才会取到正确的值。
  • Oracle 这样取序列的情况,需要设置为 before,否则会报错。

xml 的例子:

<insert id="insert" parameterType="map"> 
  insert into table1 (name) values (#{name}) 
  <selectKey resultType="java.lang.Integer" keyProperty="id"> 
   SELECT LAST_INSERT_ID() AS id 
  </selectKey> 
</insert>

上面 xml 的传入参数是 map,selectKey 会将结果放到入参数 map 中。用 POJO 的情况一样,但是有一点需要注意的是,keyProperty 对应的字段在 POJO 中必须有相应的 setter 方法,setter 的参数类型还要一致,否则会报错。

注解的形式:

@Insert("insert into table2 (name) values(#{name})") 
@SelectKey(statement="call identity()", keyProperty="nameId", before=false, resultType=int.class) 
int insertTable2(Name name); 

方法七:使用<insert 中的useGeneratedKeys 和 keyProperty 两个属性

1.在Mybatis Mapper文件中添加属性 “useGeneratedKeys”和“keyProperty”,其中 keyProperty 是 Java 对象的属性名,而不是表格的字段名。

<insert id="insert" parameterType="Spares"   
    useGeneratedKeys="true" keyProperty="id">  
    insert into system(name) values(#{name})  
</insert> 

2.Mybatis 执行完插入语句后,自动将自增长值赋值给对象 systemBean 的属性id。因此,可通过 systemBean 对应的 getter 方法获取!

int count = systemService.insert(systemBean);  
int id = systemBean.getId(); //获取到的即为新插入记录的ID 

【注意事项】

1.Mybatis Mapper 文件中,“useGeneratedKeys” 和 “keyProperty” 必须添加,而且 keyProperty 一定得和 java 对象的属性名称一直,而不是表格的字段名。

2. java Dao中的 Insert 方法,传递的参数必须为 java 对象,也就是 Bean,而不能是某个参数。

到此这篇关于详解mysql插入数据后返回自增ID的七种方法的文章就介绍到这了,更多相关mysql插入返回自增ID内容请搜索


标签:SQL

返回前面的内容

相关阅读 >>

sql怎么修改表内容

sql server 编译与重编译详解

sql删除表的命令有哪些

spark sql数据加载和保存实例讲解

sql怎么使用触发器

适合python项目的五大sql连接器

sql如何在原有表基础上增加一列

pandas操作mysql的方法详解

删除表字段的sql语句有哪些?

sql server 交集,差集的用法详解

更多相关阅读请进入《sql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...