PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Plusieurs générateurs de séquence Hibernate pour une entité avec PostgreSQL

Non vous ne pouvez pas. Le générateur s'applique uniquement aux colonnes d'identifiant.

Assurez-vous de créer cette séquence avec un script (par exemple hibernate.hbm2ddl.import_files ):

create sequence subscription_code_1_seq start 1 increment 7

Utilisez ensuite un mappage comme celui-ci :

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