如何获取数据表中自增主键的值

Posted 咕噜噜zmj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何获取数据表中自增主键的值相关的知识,希望对你有一定的参考价值。

一、mysql数据库

  当向数据库中插入一条数据的时候,默认是拿不到自增主键的值的, 需要设置如下两个属性才可以拿到主键值!

  设置userGeneratedKeys属性值为true:使用自动增长的主键。使用keyProperty设置把主键值设置给哪一个属性

1   <insert id="addEmp" parameterType="com.neuedu.mybatis.bean.Employee" useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
2     insert into tbl_employee(last_name,email,gender) 
3     values(#{lastName},#{gender},#{email})
4   </insert>

二、Oracle数据库

  1、需要在oracle数据库中创建自增序列

      create sequence emp_seq
      start with 1;

   2、在sql映射文件中配置:

      order="BEFORE" :设置selectKey中包含的语句先执行

      resultType:指定返回类型

      keyProperty:将返回值赋值给指定的列

1   <!-- Oracle数据库获取主键自增 -->
2   <insert id="insert" databaseId="oracle">
3     <selectKey keyProperty="id" resultType="int" order="before">
4       select emp_seq.nextval from dual
5     </selectKey>
6     insert into tbl_emp values(#{id},#{lastName},#{gender},#{email})
7   </insert>

 



以上是关于如何获取数据表中自增主键的值的主要内容,如果未能解决你的问题,请参考以下文章

mybatis记录随便保存数据获取自增主键的值

[mybatis]Mapper XML Files_获取自增主键的值

如何修改mysql主键的值为自增

java面试一日一题:mysql中的自增主键

Mybatis返回自增主键的xml方式

提取自增主键的标准做法是啥?