[英]Embedded Id is set to null
我有以下實體:
@Entity
@Table(name = "B_Message")
public class Message implements java.io.Serializable {
@Id
@GeneratedValue(generator = "app-uuid")
@Column(name = "MessageID", unique = true, nullable = false, length = 36, columnDefinition = "uniqueIdentifier")
private String id;
@OneToMany(cascade= {CascadeType.PERSIST, CascadeType.MERGE}, fetch = FetchType.LAZY, mappedBy = "message")
private Set<MessageReceiver> messageReceivers;
}
和
@Entity
@Table(name="B_MessageReceiver")
public class MessageReceiver implements java.io.Serializable {
@EmbeddedId
@AttributeOverrides( {
@AttributeOverride(name="messageId", column=@Column(name="MessageID", nullable=false, length=36, columnDefinition = "uniqueIdentifier") ),
@AttributeOverride(name="accountabilityId", column=@Column(name="AccID", nullable=false, length=36, columnDefinition = "uniqueIdentifier") ) } )
private MessageReceiverId id;
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="MessageID", nullable=false, insertable=false, updatable=false)
private Message message;
}
和
@Embeddable
public class MessageReceiverId implements java.io.Serializable {
@Column(name = "MessageID", nullable = false, length = 36)
private String messageId;
@Column(name = "AccID", nullable = false, length = 36)
private String accountabilityId;
}
我在以下代碼中使用它們
Message message = new Message();
Set<MessageReceiver> messageReceivers = new HashSet<MessageReceiver>();
MessageReceiver messageReceiver = new MessageReceiver();
MessageReceiverId messageReceiverId = new MessageReceiverId();
messageReceiverId.setAccountabilityId(this.accountabilityModel.getId());
messageReceiver.setMessage(message);
messageReceiver.setId(messageReceiverId);
messageReceivers.add(messageReceiver);
messageManager.saveMessage(message);
但是,當我想合並Message
實體時,未設置MessageReceiverId
的messageId
並將其發送給數據庫。
問題是您的嵌入式ID是兩個字段的組合,即messageId
和accountabilityId
但是在您的代碼中,您僅將一個值設置為accountabilityId
:
messageReceiverId.setAccountabilityId(this.accountabilityModel.getId());
這是因為丟失設置messageId
,這就是為什么你將有一個null
的值messageId
,因為你需要設置兩個字段值,所以他們不會是null
,你只需要設置一個messageId
太:
messageReceiverId.setMessageId(message.getId());/* the id value here */
編輯:
在將message
對象及其ID分配給messageReceiver
之前,將message
對象保存在數據庫中,然后此行:
messageManager.saveMessage(message);
誰可能在此之前:
messageReceiver.setMessage(message);
然后最后,將messageReceiver
對象保存在數據庫中。
我找到了以下解決方案:
對於MessageReceiver
實體的message
屬性,我應該添加@MapsId
例如:
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="MessageID", nullable=false, insertable=false, updatable=false)
@MapsId("messageId")
private Message message;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.