5

我正在使用上面的代码来生成 id:

@Id
@GeneratedValue(generator = "seqq")
@SequenceGenerator(name = "seqq", sequenceName = "seqq", allocationSize = 20, initialValue = 1)
public long getId() {
    return id;
}

我还更新了 persistence.xml:

   <property name="hibernate.id.new_generator_mappings" value="true"/>

并更新数据库中的 ddl:

CREATE SEQUENCE seqq
  INCREMENT 20
  MINVALUE 1
  MAXVALUE 9223372036854775807
  START 9171
  CACHE 1;

由于这个 allocationSize = 20 与增量值相同。但是,我得到任意错误,说重复键值违反了唯一约束“myobjects_pkey”。通常在第一次保存试用后会发生此错误。似乎休眠试图保持具有相同 ID 的实体。但是 START 确保该行高于 table id 中现有的任何行。如何消除重复约束错误?

4

3 回答 3

0

设置 hibernate.id.new_generator_mappings=true 后,Hibernate 将生成以 LASTPRODUCEDID-ALLOCATIONSIZE 开头的 id 值。我使用默认的 50 allocationSize 经历了以下情况:

使用新生成器之前:

   entity.id          SEQ last number
     48847                  48847
     48848                  48848
     48849                  48849
     48850                  48850

使用新生成器后:

   entity.id          SEQ last number
     48801                  48851
     48802                  48852

因此,您必须增加分配大小的序列。由于您的序列的 by 子句的增加应该等于 allocationSize,这意味着只需查询您的序列的 nextval。您可以使用以下脚本执行此操作:

 DECLARE
    v NUMBER;
  BEGIN
    FOR r IN (select sequence_name from user_sequences) LOOP
      EXECUTE IMMEDIATE 'SELECT '|| r.sequence_name ||' .NEXTVAL FROM DUAL' INTO v;
    END LOOP;
  END;
  /
于 2014-01-10T19:48:09.170 回答
0

尝试指定策略如下:

@GeneratedValue(strategy=GenerationType.SEQUENCE, generator = "seqq")

于 2013-04-04T11:03:40.510 回答
0

尝试这个

    /** The identity. */
    @Id
    @Column(name = "id", unique = true, nullable = false)
    @SequenceGenerator(name = "ID_SEQU_GENERATOR", sequenceName = "DB_SEQ")
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "ID_SEQU_GENERATOR")
    public long getId() {
       return id;
    }

DB_SEQ这应该在DB as sequence.

于 2013-04-04T11:23:28.477 回答