java mybaits oracle插入返回主键

在MyBatis中,要实现在插入数据后返回主键,可以在Mapper的XML文件中使用useGeneratedKeys属性和keyProperty属性。以下是一个示例:

首先,确保你的Oracle表有一个可以自动生成主键的字段,比如使用Oracle的序列。

sql 复制代码
CREATE TABLE example_table (
  id NUMBER GENERATED BY DEFAULT ON NULL AS IDENTITY,
  name VARCHAR2(100),
  PRIMARY KEY (id)
);
 
CREATE SEQUENCE example_table_seq START WITH 1 INCREMENT BY 1;

然后,在MyBatis的Mapper XML文件中,你可以这样配置:

sql 复制代码
<insert id="insertExample" useGeneratedKeys="true" keyProperty="id">
  SELECT example_table_seq.NEXTVAL FROM DUAL;
  INSERT INTO example_table (id, name)
  VALUES (example_table_seq.CURRVAL, #{name})
</insert>

或者

sql 复制代码
<mapper namespace="com.example.mapper.YourMapper">  
  
    <!-- 假设你有一个名为YOUR_SEQ的Oracle序列 -->  
  
    <insert id="insertYourEntity" parameterType="com.example.entity.YourEntity">  
        <!-- 先使用selectKey获取序列的下一个值 -->  
        <selectKey keyProperty="id" resultType="java.lang.Long" order="BEFORE">  
            SELECT YOUR_SEQ.NEXTVAL FROM DUAL  
        </selectKey>  
          
        <!-- 然后将获取到的序列值作为主键插入到表中 -->  
        INSERT INTO your_table (id, column1, column2, ...)  
        VALUES (#{id}, #{property1}, #{property2}, ...)  
    </insert>  
  
</mapper>

这里的useGeneratedKeys设置为true表示我们想要获取数据库生成的主键,keyProperty设置为Java对象中的属性名,用于存储主键值。

在Java代码中,你的Mapper接口可能看起来像这样:

java 复制代码
public interface ExampleMapper {
  int insertExample(Example example);
}
 
public class Example {
  private int id;
  private String name;
 
  // getters and setters
}

当你调用insertExample方法并传入一个Example对象时,插入操作执行后,MyBatis会自动将生成的主键值设置到这个对象的id属性中。

相关推荐
Dicky-_-zhang13 小时前
日志管理实战:ELK与Loki对比选型与落地实践
java·jvm
nJI74egg113 小时前
JavaEE初阶---《JUC 并发编程完全指南:组件用法、原理剖析与面试应答》
java·面试·java-ee
刮风那天13 小时前
Android AMS创建进程不用Binder而用Socket?
android·java·binder
程序员老邢13 小时前
【技术底稿 37】Spring Boot 3.x 自动装配 “死锁” 排查:3 个注解实现条件化装配与 Mock 兜底
java·spring boot·后端·自动装配·rag·技术底稿
学习,学习,在学习13 小时前
Qt工控仪器程序框架设计详解(工控多仪器控制版本)
开发语言·c++·qt
三品吉他手会点灯13 小时前
C语言学习笔记 - 35.数据类型 - printf函数的非输出控制符与格式优化
c语言·开发语言·笔记·学习
日月云棠14 小时前
JAVA数据结构与算法 - 基础:链表
java·后端
日月云棠14 小时前
JAVA数据结构与算法 - 基础:栈 (Stack) 深度解析
java·后端
xiguolangzi14 小时前
java使用Map映射遍历方法
java·后端
日月云棠14 小时前
JAVA数据结构与算法 - 基础:队列 (Queue) 全方位解析
java·后端