SqlSessionFactoryBuilder和SqlSessionFactory以及SqlSession

1.1. SqlSession的使用範圍
SqlSession中封裝了對數據庫的操作,如:查詢、插入、更新、刪除等。
SqlSession通過SqlSessionFactory創建。
SqlSessionFactory是通過SqlSessionFactoryBuilder進行創建。

1.1.1. SqlSessionFactoryBuilder
SqlSessionFactoryBuilder用於創建SqlSessionFacoty,SqlSessionFacoty一旦創建完成就不需要SqlSessionFactoryBuilder了,因爲SqlSession是通過SqlSessionFactory創建的。所以可以將SqlSessionFactoryBuilder當成一個工具類使用,最佳使用範圍是方法範圍即方法體內局部變量。

1.1.2. SqlSessionFactory

       SqlSessionFactory是一個接口,接口中定義了openSession的不同重載方法,SqlSessionFactory的最佳使用範圍是整個應用運行期間,一旦創建後可以重複使用,通常以單例模式管理SqlSessionFactory。

1.1.3. SqlSession
       SqlSession是一個面向用戶的接口,sqlSession中定義了數據庫操作方法。
       每個線程都應該有它自己的SqlSession實例。SqlSession的實例不能共享使用,它也是線程不安全的。因此最佳的範圍是請求或方法範圍。絕對不能將SqlSession實例的引用放在一個類的靜態字段或實例字段中。


       打開一個 SqlSession;使用完畢就要關閉它。通常把這個關閉操作放到 finally 塊中以確保每次都能執行關閉





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章