springboot整合orcle关于主键自增问题

本文介绍了在Oracle12版本及以上数据库中如何在建表时直接使用IDENTITY关键字实现自增ID,以及在12版本以下通过序列和触发器配合MyBatisPlus进行ID生成的方法。还展示了如何在MyBatisPlus配置文件中设置OracleKeyGenerator以支持序列生成ID。
摘要由CSDN通过智能技术生成
  • orcle12版本及以上可在建表语句中设定自增:

--使用自增功能 
id number(11) generated by default as IDENTITY,
...
  • 12版本以下实现:

--首先建一个表USER_INFO
create table USER_INFO
(
    ID number(11) not null
        constraint USER_INFO_PK
        primary key,
    NAME    VARCHAR2(20) not null,
    ADDRESS VARCHAR2(30),
    SEX     VARCHAR2(4) not null
)

-- 再建一个序列SEQ_TEST
create sequence SEQ_TEST
    minvalue 1 -- 最小值
    nomaxvalue        -- 不设置最大值
   start with 1      -- 从1开始计数
   increment by 1    -- 每次加1个
   nocycle           -- 一直累加,不循环
   nocache;
-- 不建缓冲区 cache n  / nocache  --其中n代表一个整数,默认值为20
--------------------------------------------
create sequence product_id_seq increment by 1 start with 1;
--------------------------------------------

-- 触发器可省略,省略情况下用序列名.nextval获取id:
insert into USER_INFO (ID, NAME, ADDRESS, SEX)
values (SEQ_TEST.nextval, '吴木木', '兰州', '男生');

-- 创建一个触发器
CREATE
OR REPLACE TRIGGER tg_test /*触发器*/
   BEFORE INSERT ON TEST_tab /*表*/ FOR EACH ROW /* WHEN (new.nid is null)*/
begin
select /*序列*/seq_test.nextval
into :new.nid/*主键*/
from dual;
-- select /*序列*/seq_test.nextval into:new.id/*主键*/ from dual;
end;
  • 配置

-- 配置
@Configuration
public class MybatisPlusConfig {
    @Bean
    public OracleKeyGenerator oracleKeyGenerator(){
        return new OracleKeyGenerator();
}
}
  • pojo

@Data
@Accessors(chain = true)
@TableName(value = "USER_INFO")
//序列名
@KeySequence(value = "SEQ_TEST")
public class UserInfo implements Serializable {
    private static final long serialVersionUID = 929439337157294297L;
    @TableId(value = "ID",type = IdType.INPUT)
    private long id;

    private String name;

    private String address;

    private String sex;

}

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值