Mybatis如何获取生成的主键呢?

欣喜 MyBatis 发布时间:2023-12-07 11:21:49 阅读数:6065 1
下文笔者讲述Mybatis获取生成主键的方法及示例分享,如下所示

Mybatis获取生成主键的方法

     mybatis中useGeneratedKeys设置为true,然后获取主键     

mybatis获取主键自增值

MySQL

<!-- useGeneratedKeys 设置为"true" 
    指MyBatis 要获取由数据库自动生成的主键
     keyColumn指定数据库主键
     keyProperty指定 Java 实体类中对应的主键字段 -->

<insert id="insertUser" useGeneratedKeys="true" keyProperty="userId" >
  insert into user(
  user_name, user_password, create_time)
  values(#{userName}, #{userPassword} , #{createTime, jdbcType= TIMESTAMP})
</insert>

parameterType 可不写
    Mybatis可以推断出传入的数据类型
    如果想要访问主键
     那么parameterType 应当是java实体或Map
     这样数据在插入之后可通过java实体或Map来获取主键值

不支持主键自增的数据库(Oracle)

Oracle数据库
   未提供主键自增的功能
   而使用序列的方式获取自增主键

   可使用selectKey标签来获取主键的值
    这种方式不仅适用于不提供主键自增功能的数据库
    也适用于提供主键自增功能的数据库<selectKey>标签一般的用法

<insert id="insertUser" >
<selectKey keyColumn="id" resultType="long" keyProperty="userId" order="BEFORE">
SELECT USER_ID.nextval as id from dual
</selectKey>
insert into user(
user_id,user_name, user_password, create_time)
values(#{userId},#{userName}, #{userPassword} , #{createTime, jdbcType= TIMESTAMP})
</insert>

相关属性说明

属性 备注
keyProperty selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表
keyColumn 匹配属性的返回结果集中的列名称。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表
resultType 结果的类型,MyBatis 通常可以推算出来。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map
order 值可为BEFORE 或 AFTER。如果是 BEFORE,那么它会先执行selectKey设置 keyProperty 然后执行插入语句。如果为AFTER则相反
statementType 使用何种语句类型,默认PREPARED。有STATEMENT,PREPARED 和 CALLABLE 语句的映射类型。 此时会将Oracle生成的主键值赋予userId变量。这个userId 就是USER对象的属性,这样就可以将生成的主键值返回了 如果仅仅是在insert语句中使用但是不返回,此时keyProperty=“任意自定义变量名 resultType 可以不写。Oracle 数据库中的值要设置为 BEFORE ,这是因为 Oracle中需要先从序列获取值,然后将值作为主键插入到数据库中
注意事项:
      Mysql使用selectKey的方式获取主键
          order :AFTER
        获取递增主键值 :SELECT LAST_INSERT_ID()
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接: https://www.Java265.com/JavaFramework/MyBatis/202312/7406.html

最近发表

热门文章

好文推荐

Java265.com

https://www.java265.com

站长统计|粤ICP备14097017号-3

Powered By Java265.com信息维护小组

使用手机扫描二维码

关注我们看更多资讯

java爱好者