詳解Hibernate Session
本文向大家介紹Hibernate Session,可能好多人還不了解Hibernate Session,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會你更多東西。
Hibernate的基本特征是完成面向?qū)ο蟮某绦蛟O(shè)計語言到關(guān)系數(shù)據(jù)庫的映射,在Hibernate中使用持久化對象PO(Persistent Object)完成持久化操作,對PO的操作必須在Session管理下才能同步到數(shù)據(jù)庫,但是這里的Session并非指HttpSession,可以理解為基于JDBC的Connnection,Session是Hibernate運作的中心,對象的生命周期、事務(wù)的管理、數(shù)據(jù)庫的存取都與Session息息相關(guān),首先,我們需要知道,SessionFactory負責(zé)創(chuàng)建Session,SessionFactory是線程安全的,多個并發(fā)線程可以同時訪問一個SessionFactory 并從中獲取Session實例。而Session并非線程安全,也就是說,如果多個線程同時使用一個Session實例進行數(shù)據(jù)存取,則將會導(dǎo)致Session 數(shù)據(jù)存取邏輯混亂.因此創(chuàng)建的Session實例必須在本地存取空上運行,使之總與當(dāng)前的線程相關(guān)。
這里就需要用到ThreadLocal,在很多種Session 管理方案中都用到了它.ThreadLocal 是Java中一種較為特殊的線程綁定機制,通過ThreadLocal存取的數(shù)據(jù),總是與當(dāng)前線程相關(guān),也就是說,JVM 為每個運行的線程,綁定了私有的本地實例存取空間,從而為多線程環(huán)境常出現(xiàn)的并發(fā)訪問問題提供了一種隔離機制,ThreadLocal并不是線程本地化的實現(xiàn),而是線程局部變量。
也就是說每個使用該變量的線程都必須為該變量提供一個副本,每個線程改變該變量的值僅僅是改變該副本的值,而不會影響其他線程的該變量的值,ThreadLocal是隔離多個線程的數(shù)據(jù)共享,不存在多個線程之間共享資源,因此不再需要對線程同步。
請看一下代碼:
- public class HibernateUtil {
- public static final SessionFactory sessionFactory;
- public static final ThreadLocal session = new ThreadLocal();
- static{
- try{
- Configuration configuration=new Configuration().configure();
- sessionFactory = configuration.buildSessionFactory();
- }catch (Throwable ex){
- System.err.println("Initial SessionFactory creation failed." + ex);
- throw new ExceptionInInitializerError(ex);
- }
- }
- public static Session currentSession() throws HibernateException{
- Session s = (Session) session.get();
- if (s == null)
- {
- s = sessionFactory.openSession();
- session.set(s);
- }
- return s;
- }
- public static void closeSession() throws HibernateException {
- Session s = (Session) session.get();
- if (s != null)
- s.close();
- session.set(null);
- }
- }
以上介紹Hibernate Session。
【編輯推薦】