1. 程式人生 > >spring data jpa session 查詢時 session 已經關閉問題

spring data jpa session 查詢時 session 已經關閉問題

前提:首先我的專案架構,採用的是spring boot + jpa 實現的。因此模型之間的關係就不得不採用 一對多,和多對一等關係來標識。

情景:一對多情況,我一個老師,和 多個學生,因此在 老師模型中建立了OneToMany關係,

@OneToMany(mappedBy = "teacher")
private Set<Student> studentSet;//學生集合
當我在進行單元測試查詢老師時,並帶出學生的集合時,報出異常:
@Test
public void query()
{
Teacher teacher = xxxDao.queryById(1);
teacher.getStudentSet();
}
org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role...
could not initialize proxy - no Session...
解決辦法:
由於引用的是spring boot,所以只需要在配置檔案中,加上

spring.jpa.open-in-view: true,

並且在呼叫的方法上 加上事物註解 @Tractional 即可

(這裡不得不強調,spring boot的強大之處,原本需要載入很多依賴檔案和XML中的配置,如今spring boot 自動幫我需要的都注入了)
原因:
由於使用jpa建立關係對映時,預設的都是 懶載入,只有當我們用到了,再去查詢,因此,查詢依賴的集合屬性時,session 已經關閉,
加上

spring.jpa.open-in-view: true的意思是

1.session 會在 此次request 的Thread 中結束後,就會關閉

2.如果到了view 層,filter會自動關閉session

這裡涉及到jpa session 問題,大家可以具體搜尋相關資料進行研究