第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

獲取惰性 OneToOne 實(shí)體會(huì)獲取同一對(duì)象內(nèi)的所有其他 OneToOne 實(shí)體

獲取惰性 OneToOne 實(shí)體會(huì)獲取同一對(duì)象內(nèi)的所有其他 OneToOne 實(shí)體

守著星空守著你 2023-03-17 13:44:36
使用Entity entity = hibernateTemplate.get(Entity.class, id);when I hit a entity.getChild()which is a OneToOne relation,所有其他 OneToOne 關(guān)系也被加載。我使用休眠 5.4.1-Final。我使用字節(jié)碼增強(qiáng)如下:<configuration>    <failOnError>true</failOnError>    <enableLazyInitialization>true</enableLazyInitialization>    <enableDirtyTracking>false</enableDirtyTracking>     <enableAssociationManagement>true</enableAssociationManagement></configuration>A.java@Entity@Table(name = "A")public class A {    @Id    @Column(name = "ID_A")    private String id;    @OneToOne(fetch = FetchType.LAZY)    @JoinColumn(name = "ID_A")    @LazyToOne(LazyToOneOption.NO_PROXY)    private B b;    @OneToOne(fetch = FetchType.LAZY)    @JoinColumn(name = "ID_A")    @LazyToOne(LazyToOneOption.NO_PROXY)    private C c;...getters/setters...B.java@Entity@Table(name = "B")public class B {    @Id    @Column(name = "ID_A")    private String id;}C.java@Entity@Table(name = "C")public class C {    @Id    @Column(name = "ID_A")    private String id;}所以當(dāng)我做A a = hibernateTemplate.get(A.class, "100"); // triggers an Hibernate query only on A entity. The B and C aren't fetched => OK// Hibernate: select a0_.ID_A as ID_A_27_0_ from A a0_ where a0_.ID_A=?a.getB(); // ERROR : triggers two queries : one on C and one on B// Hibernate: select c0_.ID_A as ID_A _26_0_ from C c0_ where c0_.ID_A =?// Hibernate: select b0_.ID_A as ID_A _13_0_ from B b0_ where b0_.ID_A =?即使我獲取了B一個(gè)HQLQuery,我仍然有一個(gè)查詢C:Query<A> queryA = hibernateTemplate.createHQLQuery("from A a join fetch a.b where a.id=:id", A.class);queryA.setParameter("id", "100");A a = queryA.uniqueResult(); // triggers an inner join// Hibernate: select a0_.as ID_A1_27_0_, b1_.ID_A as ID_A1_13_1_ from A a0_ inner join B b1_ on a0_.ID_A=b1_.ID_A where a0_.ID_A=? a.getB(); // KO -> triggers a query to select C !// Hibernate: select c0_.ID_A as ID_A1_26_0_ from C c0_ where c0_.ID_A=?我嘗試進(jìn)行雙映射(指定了 mappedBy 的 OneToOne)但沒(méi)有成功。B和C的PK和A一樣。我希望a.getB();不會(huì)觸發(fā) C 的獲取。這是一個(gè)休眠錯(cuò)誤嗎?我在他們的文檔中找不到有關(guān)此行為的任何信息。我的映射正確嗎?
查看完整描述

1 回答

?
largeQ

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊

它似乎按設(shè)計(jì)工作:) b 和 c 屬于相同的默認(rèn)“LazyGroup”。如果需要加載 b 或 c 中的任何一個(gè),則整個(gè)組都會(huì)加載。

引用字節(jié)碼增強(qiáng)器文檔:

惰性屬性可以指定一起加載,這稱(chēng)為“惰性組”。默認(rèn)情況下,所有單數(shù)屬性都是單個(gè)組的一部分,這意味著當(dāng)訪問(wèn)一個(gè)惰性單數(shù)屬性時(shí),將加載所有惰性單數(shù)屬性。惰性復(fù)數(shù)屬性,默認(rèn)情況下,每個(gè)屬性都是一個(gè)惰性組。此行為可通過(guò) @org.hibernate.annotations.LazyGroup 注釋顯式控制。

@LazyGroup("b")只需在 b 字段和 c 上添加,它應(yīng)該按預(yù)期工作:b 將僅在, anc c on 上@LazyGroup("c")加載。getB()getC()

更多關(guān)于這里這里。


查看完整回答
反對(duì) 回復(fù) 2023-03-17
  • 1 回答
  • 0 關(guān)注
  • 167 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)