PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Vários geradores de sequência Hibernate para uma entidade com PostgreSQL


Não, você não pode. O gerador é aplicável apenas para colunas identificadoras.

Certifique-se de criar esta sequência com um script (por exemplo, hibernate.hbm2ddl.import_files ):
create sequence subscription_code_1_seq start 1 increment 7

Em seguida, use um mapeamento como este:
@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;