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 サイトの他の関連記事を参照してください。