簡體   English   中英

Hibernate一到零或一個映射

[英]Hibernate one to zero or one mapping

我正試圖在Hibernate中將一個映射到“零或一”關系。 我想我可能找到了一種使用多對一的方法。

class A {
  private B b;
  // ... getters and setters
}

class B {
  private A a;
}

A類的映射指定:

<many-to-one name="b" class="B" 
insert="false" update="false" 
column="id" unique="true"/>

和B類的映射指定:

<one-to-one name="a" class="A" constrained="true"/>

我想要的是,當在數據庫中找不到B的匹配行時,b為null。 所以我可以這樣做(在A級):

if (b == null)

但是,似乎b永遠不會為空。

我該怎么辦?

像Boden說的那樣,答案是在A中的多對一語句中添加not-found="ignore" 。使用注釋執行此操作:

在A類:

@ManyToOne
@Cascade({ CascadeType.ALL })
@JoinColumn(name = "Id")
@NotFound(action=NotFoundAction.IGNORE)
private B b

在B類:

@Id
@GeneratedValue(generator = "myForeignGenerator")
@org.hibernate.annotations.GenericGenerator(
    name = "myForeignGenerator",
    strategy = "foreign",
    parameters = @Parameter(name = "property", value = "a")
)
private Long subscriberId;

@OneToOne(mappedBy="b")
@PrimaryKeyJoinColumn
@NotFound(action=NotFoundAction.IGNORE)
private A a;

答案是在A中的多對一語句中添加not-found =“ignore”:

<many-to-one name="b" class="B" not-found="ignore" insert="false" update="false" column="id" unique="true"/>

我試着像Rob H推薦的那樣簡單地將lazy =“false”添加到B,但每次加載沒有B的A時都會導致HibernateObjectRetrievalFailureException。

請參閱本主題以獲取更多信息:

https://forum.hibernate.org/viewtopic.php?p=2269784&sid=5e1cba6e2698ba4a548288bd2fd3ca4e

嘗試在多對一元素上設置lazy =“false”。 這應該強制Hibernate在加載第一個對象(“A”)時嘗試獲取關聯(“B”)。 “A”中的屬性將使用“B”的實例或null進行初始化。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM