PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Più generatori di sequenze Hibernate per un'entità con PostgreSQL

No, non puoi. I generatori sono applicabili solo alle colonne identificatore.

Assicurati di creare questa sequenza con uno script (ad es. hibernate.hbm2ddl.import_files ):

create sequence subscription_code_1_seq start 1 increment 7

Quindi usa una mappatura come questa:

@Id
@SequenceGenerator(
        name="subscription_id_seq",
        sequenceName="subscription_id_seq",
        allocationSize=7
)
@GeneratedValue(
        strategy=GenerationType.SEQUENCE,
        generator="subscription_id_seq"
)
@Column(unique=true, nullable=false)
private Integer id;

@Column(
        name="code",
        nullable=false,
        unique=true,
        insertable = false,
        updatable = false,
        columnDefinition = "BIGINT DEFAULT nextval('subscription_code_1_seq')"
)
@Generated(GenerationTime.INSERT)
private Integer code;