SpringDataJPA使用Oracle序列设置值:主键字段、非主键字段

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringDataJPA使用Oracle序列设置值:主键字段、非主键字段相关的知识,希望对你有一定的参考价值。

参考技术A 项目使用SpringDataJPA+Hibernate+Oracle,使用Oracle序列设置Entity对应的主键值,这个很常见。实现步骤如下:
1>创建一个Oracle序列:

2>在实体中引用:

现在同一个Entity实体的,另一个非主键字段也需要使用序列来设置值。后来自己发现:不能在同一个Entity中,通过@GeneratedValue和@SequenceGenerator标签使用多个Oracle序列。

使用SpringDataJPA的原生sql语句查询序列的下一个值。然后在service层调用此方法获取下一个序列值,手动设置到Entiry的非主键字段上去。

参考文章:
1.How do you get a Oracle Sequence value with JPA?
2.SpringDataJPA原生sql语句执行

Oracle:将序列设置为特定值[重复]

【中文标题】Oracle:将序列设置为特定值[重复]【英文标题】:Oracle: Setting sequence to a specific value [duplicate] 【发布时间】:2012-07-26 14:29:30 【问题描述】:

我正在使用 liquibase 来管理我的架构。我有一堆插入语句。我已经硬编码了主 ID 号码。完成所有插入后,我想将序列值更改为比表中主键的最大值大 1。为此,我编写了如下所示的 PL/SQL。但是,当我执行 select ArtifactTypes_id_seq.nextval from dual; 时,它仍然会递增 0。

SET SERVEROUTPUT ON SIZE 1000000
DECLARE
    sequence_id NUMBER;
BEGIN

    SELECT NVL(MAX(idArtifactType), 0) + 1 INTO sequence_id FROM ArtifactTypes;
    EXECUTE IMMEDIATE 'ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY ' || sequence_id;
    EXECUTE IMMEDIATE 'SELECT ArtifactTypes_id_seq.nextval FROM dual';
    EXECUTE IMMEDIATE 'ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY 1';
    DBMS_OUTPUT.put_line('Executed "ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY ' || sequence_id || '"');
END;
/

DBMS_OUTPUT 给出以下输出 - Executed "ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY 71"

我错过了什么?我做错了吗? 注意:我尝试从 SQLDeveloper 执行这些 SQL。

【问题讨论】:

【参考方案1】:

所以我发现了问题。以下应该是 PL/SQL -

SET SERVEROUTPUT ON SIZE 1000000
DECLARE
    sequence_id NUMBER;
    temp_seq NUMBER;
BEGIN
    SELECT NVL(MAX(idArtifactType), 0) + 1 INTO sequence_id FROM ArtifactTypes;
    EXECUTE IMMEDIATE 'ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY ' || sequence_id;
    SELECT ArtifactTypes_id_seq.nextval into temp_seq FROM dual;
    EXECUTE IMMEDIATE 'ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY 1';
    DBMS_OUTPUT.put_line('Executed "ALTER SEQUENCE saas.ArtifactTypes_id_seq INCREMENT BY ' || sequence_id || '"');
END;
/

以下声明 - EXECUTE IMMEDIATE 'SELECT ArtifactTypes_id_seq.nextval FROM dual'; 改为 SELECT ArtifactTypes_id_seq.nextval into temp_seq FROM dual;

它成功了!!

【讨论】:

【参考方案2】:

您需要删除序列然后重新创建它,使用 STARTS WITH 子句分配初始值,例如:

CREATE SEQUENCE saas.ArtifactTypes_id_seq
  START WITH 72;

此外,从序列中选择 NEXTVAL 会自动将其递增 1。

【讨论】:

以上是关于SpringDataJPA使用Oracle序列设置值:主键字段、非主键字段的主要内容,如果未能解决你的问题,请参考以下文章

oracle创建序列的语法

Oracle:将序列设置为特定值[重复]

oracle怎么实现id自增和设置主键啊

oracle自增主键从多少开始

如何使用Spring Data JPA在实体中映射Oracle Object类型?

oracle设置自动增长序列