4

すべてのエンティティが基本抽象エンティティから継承されるエンティティを保存するために Hibernate を使用しています。すべての具体的なエンティティには、自動インクリメントの主キー列を持つデータベース テーブルがそれぞれあります。ただし、GenerationType を「AUTO」または「IDENTITY」として使用すると、エラーが発生します。各具体的なエンティティ クラスを表すデータベース テーブル内のすべてのレコードに、順次インクリメントされた ID 値が必要です。

com.something.SuperClass:

@Entity
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class SuperClass implements Serializable {
    private static final long serialVersionUID = -695503064509648117L;

    long confirmationCode;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO) // Causes exception!!!
    public long getConfirmationCode() {
        return confirmationCode;
    }

    public void setConfirmationCode(long confirmationCode) {
        this.confirmationCode = confirmationCode;
    }
}

com.something.SubClass:

@Entity
public abstract class Subclass extends SuperClass {
    private static final long serialVersionUID = 8623159397061057722L;

    String name;

    @Column(nullable = false)
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

私にこの例外を与えます:

Caused by: org.hibernate.MappingException: Cannot use identity column key
generation with <union-subclass> mapping for: com.something.SuperClass
What's the best and most convenient way for me to generate the ID's? I do not want to change my inheritance strategy.

GenerationType を「AUTO」から「TABLE」に変更すると解決できることはわかっていますが、このソリューションの問題は、生成されたキーが正確な順序になっていないことです。キー間に大きなギャップが残ります。

すべてのテーブルが Mysql AutoIncrement プライマリ列によって生成された Auto Incremental 値を使用できるようにするソリューションを探しています。

すべてに前もって感謝します。

PS: 私はすでに次の投稿を行っています: Cannot use identity column key generation with <union-subclass> ( TABLE_PER_CLASS )

4

1 に答える 1