org.hibernate.AnnotationException: Unknown Id.generator

org.hibernate.AnnotationException: Unknown Id.generator

Problème

Exécution du générateur de séquence d'annotation Hibernate suivant avec la base de données PostgreSQL.

        @Id
    @Column(name="user_id", nullable=false)
    @GeneratedValue(strategy = GenerationType.SEQUENCE ,generator="account_user_id_seq")
    private Integer userId;

Atteint l'exceptionId.generator inconnue suivante.

Caused by: org.hibernate.AnnotationException: Unknown Id.generator: account_user_id_seq
    at org.hibernate.cfg.BinderHelper.makeIdGenerator(BinderHelper.java:413)
    at org.hibernate.cfg.AnnotationBinder.bindId(AnnotationBinder.java:1795)
    at org.hibernate.cfg.AnnotationBinder.processElementAnnotations(AnnotationBinder.java:1229)
    at org.hibernate.cfg.AnnotationBinder.bindClass(AnnotationBinder.java:733)

La séquence «account_user_id_seq» est créée dans la base de données PostgreSQL, qu'est-ce qui a provoqué l'exception ci-dessus?

Solution

Lors de la déclaration de la stratégie d'annotation d'Hibernate pour utiliser «Sequences» comme générateur d'ID, essayez également de spécifier @SequenceGenerator, comme suit

        @Id
    @Column(name="user_id", nullable=false)
    @SequenceGenerator(name="my_seq", sequenceName="account_user_id_seq")
    @GeneratedValue(strategy = GenerationType.SEQUENCE ,generator="my_seq")
    private Integer userId;