Springboot实用系列:useGeneratedKeys用法

在Spring Boot项目中,useGeneratedKeys 是 MyBatis 框架中的一个参数,用于指定是否允许 JDBC 支持自动生成主键。这个参数可以在三个不同的位置设置:全局配置文件、XML 映射器和接口映射器。

  1. 全局配置文件 :可以在 MyBatis 的全局配置文件 mybatis-config.xml 中的 <settings> 元素内设置 useGeneratedKeys 参数。例如:

    xml 复制代码
    <settings>
        <setting name="useGeneratedKeys" value="true"/>
    </settings>

    这样设置后,所有接口映射器中的插入操作都会尝试获取自动生成的主键,但对 XML 映射器不起作用。

  2. XML 映射器 :在具体的 XML 映射文件中,可以在 <insert> 标签中设置 useGeneratedKeys 属性。例如:

    xml 复制代码
    <insert id="addBigdataGroup" parameterType="BigdataGroup" useGeneratedKeys="true" keyProperty="groupId" keyColumn="group_id">
        insert into bigdata_group (group_id, group_name, comment, business_line, create_by, remark, create_time)
        values(#{groupId}, #{groupName}, #{comment}, #{businessLine}, #{createBy}, #{remark}, sysdate())
    </insert>

    这里 keyProperty 指定了 Java 对象中的属性名,keyColumn 指定了数据库中的列名,这样在插入操作后,MyBatis 会将生成的主键值回填到对应的 Java 对象属性中。

  3. 接口映射器 :在接口映射器中,可以使用 @Options 注解来设置 useGeneratedKeys 参数。例如:

    java 复制代码
    @Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
    @Insert("insert into test(name,descr,url,create_time,update_time) values(#{name},#{descr},#{url},now(),now())")
    Integer insertOneTest(Test test);

    在这里,keyProperty 指定了 Java 对象中的属性,keyColumn 指定了数据库中的列名,useGeneratedKeys 设置为 true 表示启用自动生成主键。

请注意,如果在接口映射器中设置了 useGeneratedKeys 参数,那么这个设置会覆盖全局配置文件中相同的设置。

如果在配置了 useGeneratedKeys 后,插入操作没有返回预期的主键值,可能是因为数据库驱动不支持自动生成主键,或者配置有误。确保数据库表配置了自动生成主键,并且 JDBC 驱动支持这一特性。

相关推荐
小杍随笔几秒前
【Rust中所有符号的作用及使用场景详解】
java·算法·rust
DolphinDB智臾科技几秒前
实操教程:使用 GitHub Copilot 配置 DolphinDB Skill 以提升开发效率
数据库·github·copilot·时序数据库·dolphindb
亚马逊云开发者几秒前
别再烧 Token 了!我用这 5 个配置把 OpenClaw 费用砍了一半
java
yeshihouhou几秒前
redisson实现延迟队列
java·前端·数据库
那我掉的头发算什么3 分钟前
【Linux】Linux基本使用和程序部署
linux·运维·服务器·数据库·spring·mybatis
明码5 分钟前
Pathlib库
java·服务器·前端
程序员爱钓鱼5 分钟前
Go文件路径处理完全指南:path/filepath包详解与实战
后端·面试·go
LSL666_6 分钟前
11 redis核心配置参数
数据库·redis·缓存
爱笑的源码基地6 分钟前
基于云计算的基层医疗信息系统,springMVC框架开发的云HIS系统源码
spring boot·后端·源码·二次开发·his·源代码·医院管理信息系统
江畔柳前堤7 分钟前
XZ07_解决WORD中间单词间隔过大的问题
数据库·人工智能·线性代数·oracle·数据挖掘·word