org.hibernate.AnnotationException: Unbekannter Id.generator

org.hibernate.AnnotationException: Unknown Id.generator

Problem

Ausführen des folgenden Hibernate-Anmerkungssequenzgenerators mit der PostgreSQL-Datenbank.

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

Trifft die folgende Ausnahme von UnknownId.generator.

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)

Die Sequenz "account_user_id_seq" wird in der PostgreSQL-Datenbank erstellt. Was hat die obige Ausnahme verursacht?

Lösung

Wenn Sie die Annotationsstrategie des Ruhezustands für die Verwendung von "Sequences" als ID-Generator deklarieren, geben Sie wie folgt den @SequenceGenerator an

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