PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Mehrere Hibernate-Sequenzgeneratoren für eine Entität mit PostgreSQL

Nein, du kannst nicht. Der Generator gilt nur für Bezeichnerspalten.

Stellen Sie sicher, dass Sie diese Sequenz mit einem Skript erstellen (z. B. hibernate.hbm2ddl.import_files ):

create sequence subscription_code_1_seq start 1 increment 7

Verwenden Sie dann eine Zuordnung wie diese:

@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;