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 驱动支持这一特性。

相关推荐
北城笑笑4 分钟前
Vue 100 ,Metaspace memory lack Error( 元空间内存不足 )
java·前端·javascript·vue
掘金者阿豪8 分钟前
小爱音箱秒变智能搭子!MiGPT GUI+cpolar,远程操控超省心
后端
Han.miracle9 分钟前
Spring IoC 与 DI 核心知识点综合测试题
java·前端·数据库
_Jimmy_10 分钟前
mysql更新字段会更新索引吗
数据库·mysql
婉然从物12 分钟前
IDEA中plugins无法连接网络
java·ide·intellij-idea
xiaogai_gai12 分钟前
ETL数据流程实战:轻易云平台整合金蝶云星空API接口
java·数据仓库·etl
@PHARAOH14 分钟前
HOW - 本地基于 docker 快速构建 mysql 数据库
数据库·mysql·docker
Java编程爱好者19 分钟前
Java面试高频场景题:在工作中或者一些组件源码里面或多或少会用到锁,你能整理概括下锁的分类么?
后端
sheji341620 分钟前
【开题答辩全过程】以 基于springboot的健身预约系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
数据知道21 分钟前
MongoDB读取偏好配置:如何优化查询路由策略?
数据库·mongodb