Mybatis 插入数据后返回主键值

在使用MyBatis进行开发时,我们面临一个问题。怎样在insert的时候获取数据库自动生成的ID值呢?在不同的数据库中生成ID值的方式不一致,也就导致我们处理这一问题也不一致。在Oracle中是通过调用一个序列的nextval来获取一个唯一的ID,在MySQL和SQL Server中存在一个自增长列。因此,二者的处理方式不一致,下面我们通过实例来讲解Oracle和MySQL中怎样获取Insert后的ID值。

在使用MyBatis进行开发时,我们面临一个问题。怎样在insert的时候获取数据库自动生成的ID值呢?在不同的数据库中生成ID值的方式不一致,也就导致我们处理这一问题也不一致。在Oracle中是通过调用一个序列的nextval来获取一个唯一的ID,在MySQL和SQL Server中存在一个自增长列。因此,二者的处理方式不一致,下面我们通过实例来讲解Oracle和MySQL中怎样获取Insert后的ID值。

一、Oracle获取刚刚插入记录的主键值

在Oracle中UUID值是通过序列产生的,即“序列.nextval”的方式,如下:

SELECT U_USER_INFO_SEQ.Nextval as ID from DUAL
-- 其中U_USER_INFO_SEQ是序列名称

下面是一个MyBatis插入数据的mapper实例:

<insert id="insertUser" parameterType="com.bug315.model.UserInfo">
    <selectKey resultType="java.math.BigDecimal" order="BEFORE" keyProperty="id">
       SELECT T_USER_INFO_SEQ.Nextval as ID from DUAL
   </selectKey>
     
    insert into T_USER_INFO(N_ID, C_USERNAME, C_REALNAME) VALUES(
        #{id,jdbcType=INTEGER},
        #{username,jdbcType=VARCHAR},
        #{realname,jdbcType=VARCHAR}
    )
</insert>

这里使用了selectKey来定义返回新生成的PrimaryKey,这个情况仅仅适用于Oracle。需要注意的地方是在Java代码中使用Integer类型,但是在MyBatis的映射文件中,使用java.math.BigDecimal类型,否则会报类型转换或者不匹配的错误。

二、MySQL与SQL Server获取刚刚插入数据的主键值

在MySQL和SQL Server中支持自增长列,即“AUTO_INCREMENT”约束;因此,与Oracle的处理方式不一样,如下:

<insert id="insertUser" parameterType="hashmap"
    useGeneratedKeys="true" keyProperty="id">  
    insert into spares(
        N_ID, C_USERNAME, C_REALNAME
    ) values(
        #{id,jdbcType=INTEGER},
        #{username,jdbcType=VARCHAR},
        #{realname,jdbcType=VARCHAR}
    )  
</insert>

使用useGeneratedKeys/KeyProperty来实现插入数据的时候,来完成新生成主键的返回。

点击学习 MyBatis 教程,了解更多的 MyBatis 知识!

生活总会给你答案的,但不会马上把一切都告诉你。只要你肯等一等,生活的美好,总在你不经意的时候,盛装莅临。
0 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站专注于 Java、数据库(MySQL、Oracle)、Linux、软件架构及大数据等多领域技术知识分享。涵盖丰富的原创与精选技术文章,助力技术传播与交流。无论是技术新手渴望入门,还是资深开发者寻求进阶,这里都能为您提供深度见解与实用经验,让复杂编码变得轻松易懂,携手共赴技术提升新高度。如有侵权,请来信告知:hxstrive@outlook.com
公众号