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属性中。

相关推荐
自由随风飘3 小时前
python 题目练习1~5
开发语言·python
cynicme4 小时前
力扣3318——计算子数组的 x-sum I(偷懒版)
java·算法·leetcode
Bony-4 小时前
Go语言完全学习指南 - 从基础到精通------语言基础篇
服务器·开发语言·golang
青云交5 小时前
Java 大视界 -- Java 大数据在智能教育学习效果评估与教学质量改进实战
java·实时分析·生成式 ai·个性化教学·智能教育·学习效果评估·教学质量改进
崎岖Qiu5 小时前
【设计模式笔记17】:单例模式1-模式分析
java·笔记·单例模式·设计模式
fl1768315 小时前
基于python的天气预报系统设计和可视化数据分析源码+报告
开发语言·python·数据分析
Lei活在当下6 小时前
【现代 Android APP 架构】09. 聊一聊依赖注入在 Android 开发中的应用
java·架构·android jetpack
ACP广源盛139246256736 小时前
(ACP广源盛)GSV6172---MIPI/LVDS 信号转换为 Type-C/DisplayPort 1.4/HDMI 2.0 并集成嵌入式 MCU
c语言·开发语言·单片机·嵌入式硬件·音视频
不穿格子的程序员6 小时前
从零开始刷算法-栈-括号匹配
java·开发语言·
雪域迷影6 小时前
C#中通过get请求获取api.open-meteo.com网站的天气数据
开发语言·http·c#·get