Как создать и обработать составной первичный ключ в JPA
Я хочу иметь версии из одного и того же ввода данных. Другими словами, я хочу дублировать запись с другим номером версии.
id - Version
будет основным ключом.
Как выглядит объект? Как я могу дублировать его с другой версией?
id Version ColumnA
1 0 Some data
1 1 Some Other data
2 0 Data 2. Entry
2 1 Data
Ответы
Ответ 1
Вы можете сделать Embedded class
, который содержит ваши два ключа, а затем иметь ссылку на этот класс как EmbeddedId
в Entity
.
Вам понадобятся аннотации @EmbeddedId
и @Embeddable
.
@Entity
public class YourEntity {
@EmbeddedId
private MyKey myKey;
@Column(name = "ColumnA")
private String columnA;
/** Your getters and setters **/
}
@Embeddable
public class MyKey implements Serializable {
@Column(name = "Id", nullable = false)
private int id;
@Column(name = "Version", nullable = false)
private int version;
/** getters and setters **/
}
Другим способом достижения этой задачи является использование аннотации @IdClass
и размещение в ней id
в <<29 > . Теперь вы можете использовать стандартную аннотацию @Id
для обоих атрибутов
@Entity
@IdClass(MyKey.class)
public class YourEntity {
@Id
private int id;
@Id
private int version;
}
public class MyKey implements Serializable {
private int id;
private int version;
}
Ответ 2
Класс MyKey должен реализовывать Serializable
, если вы используете @IdClass
Ответ 3
Класс ключа:
@Embeddable
@Access (AccessType.FIELD)
public class EntryKey implements Serializable {
public EntryKey() {
}
public EntryKey(final Long id, final Long version) {
this.id = id;
this.version = version;
}
public Long getId() {
return this.id;
}
public void setId(Long id) {
this.id = id;
}
public Long getVersion() {
return this.version;
}
public void setVersion(Long version) {
this.version = version;
}
public boolean equals(Object other) {
if (this == other)
return true;
if (!(other instanceof EntryKey))
return false;
EntryKey castOther = (EntryKey) other;
return id.equals(castOther.id) && version.equals(castOther.version);
}
public int hashCode() {
final int prime = 31;
int hash = 17;
hash = hash * prime + this.id.hashCode();
hash = hash * prime + this.version.hashCode();
return hash;
}
@Column (name = "ID")
private Long id;
@Column (name = "VERSION")
private Long operatorId;
}
Класс сущностей:
@Entity
@Table (name = "YOUR_TABLE_NAME")
public class Entry implements Serializable {
@EmbeddedId
public EntryKey getKey() {
return this.key;
}
public void setKey(EntryKey id) {
this.id = id;
}
...
private EntryKey key;
...
}
Как я могу дублировать его с другой версией?
Вы можете отсоединить объект, который был получен от поставщика, изменить ключ записи и затем сохранить его как новый объект.
Ответ 4
Класс MyKey (@Embeddable) не должен иметь никаких отношений, таких как @ManyToOne
Ответ 5
При использовании аннотации @IdClass
еще один отзыв, который я нашел, - это аннотация @Column
, которая должна входить в поля класса Entity (YourEntity
в образце кода RohitJan).