ホームページ >Java >&#&チュートリアル >JPA でデータのバージョンを管理するために複合主キーをどのように使用できますか?

JPA でデータのバージョンを管理するために複合主キーをどのように使用できますか?

DDD
DDDオリジナル
2024-10-30 16:44:25571ブラウズ

How can composite primary keys be used to manage data versions in JPA?

JPA での複合主キーの作成と処理

エンティティ内のデータ バージョンを管理するには、複合主キーを作成すると、バージョン番号に基づいたエントリ。次の実装を考えてみましょう:

@Entity
public class YourEntity {
    @EmbeddedId
    private MyKey id;
    private String columnA;
    // Getters and setters omitted for brevity
}

@Embeddable
public class MyKey implements Serializable {
    private int id;
    private int version;
    // Getters and setters omitted for brevity
}

このアプローチを使用すると、id フィールドとバージョン フィールドの両方が複合主キーを形成します。これにより、データ レコードごとに複数のバージョンを作成できます:

Entity 1: id = 1, version = 0, columnA = "Data Entry 1"
Entity 2: id = 1, version = 1, columnA = "Updated Data Entry 1"

複合主キーを定義する別の方法は、@IdClass アノテーションを使用することです:

@Entity
@IdClass(MyKey.class)
public class YourEntity {
    @Id
    private int id;
    @Id
    private int version;
    private String columnA;
    // Getters and setters omitted for brevity
}

public class MyKey implements Serializable {
    private int id;
    private int version;
    // Getters and setters omitted for brevity
}

この場合、 MyKey クラスは主キー クラスとして機能し、その中の ID フィールドとバージョン フィールドには両方とも @Id アノテーションが付けられます。

@EmbeddedId または @IdClass アノテーションのいずれかを利用することで、JPA は複合主キーを効果的に管理できます。単一エンティティ内のデータ バージョンの保存と取得を容易にします。

以上がJPA でデータのバージョンを管理するために複合主キーをどのように使用できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。