本文向大家介绍Hibernate Session,可能好多人还不了解Hibernate Session,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。
Hibernate的基本特征是完成面向对象的程序设计语言到关系数据库的映射,在Hibernate中使用持久化对象PO(Persistent Object)完成持久化操作,对PO的操作必须在Session管理下才能同步到数据库,但是这里的Session并非指HttpSession,可以理解为基于JDBC的Connnection,Session是Hibernate运作的中心,对象的生命周期、事务的管理、数据库的存取都与 Session息息相关,首先,我们需要知道,SessionFactory负责创建Session,SessionFactory是线程安全的,多个并发线程可以同时访问一个SessionFactory 并从中获取Session实例。而Session并非线程安全,也就是说,如果多个线程同时使用一个Session实例进行数据存取,则将会导致 Session 数据存取逻辑混乱.因此创建的Session实例必须在本地存取空上运行,使之总与当前的线程相关。
这里就需要用到ThreadLocal,在很多种Session 管理方案中都用到了它.ThreadLocal 是Java中一种较为特殊的线程绑定机制,通过ThreadLocal存取的数据,总是与当前线程相关,也就是说,JVM 为每个运行的线程,绑定了私有的本地实例存取空间,从而为多线程环境常出现的并发访问问题提供了一种隔离机制,ThreadLocal并不是线程本地化的实现,而是线程局部变量。
也就是说每个使用该变量的线程都必须为该变量提供一个副本,每个线程改变该变量的值仅仅是改变该副本的值,而不会影响其他线程的该变量的值,ThreadLocal是隔离多个线程的数据共享,不存在多个线程之间共享资源,因此不再需要对线程同步。
请看一下代码:
1. public class HibernateUtil {
2.
3. public static final SessionFactory sessionFactory;
4. public static final ThreadLocal session = new ThreadLocal();
5.
6. static{
7.
8. try{
9.
10. Configuration configuration=new Configuration().configure();
11. sessionFactory = configuration.buildSessionFactory();
12.
13. }catch (Throwable ex){
14.
15. System.err.println("Initial SessionFactory creation failed." + ex);
16. throw new ExceptionInInitializerError(ex);
17. }
18. }
19.
20. public static Session currentSession() throws HibernateException{
21. Session s = (Session) session.get();
22. if (s == null)
23. {
24. s = sessionFactory.openSession();
25. session.set(s);
26. }
27. return s;
28. }
29.
30. public static void closeSession() throws HibernateException {
31. Session s = (Session) session.get();
32. if (s != null)
33. s.close();
34. session.set(null);
35. }
36. }
以上介绍Hibernate Session。
Hibernate的基本特征是完成面向对象的程序设计语言到关系数据库的映射,在Hibernate中使用持久化对象PO(Persistent Object)完成持久化操作,对PO的操作必须在Session管理下才能同步到数据库,但是这里的Session并非指HttpSession,可以理解为基于JDBC的Connnection,Session是Hibernate运作的中心,对象的生命周期、事务的管理、数据库的存取都与 Session息息相关,首先,我们需要知道,SessionFactory负责创建Session,SessionFactory是线程安全的,多个并发线程可以同时访问一个SessionFactory 并从中获取Session实例。而Session并非线程安全,也就是说,如果多个线程同时使用一个Session实例进行数据存取,则将会导致 Session 数据存取逻辑混乱.因此创建的Session实例必须在本地存取空上运行,使之总与当前的线程相关。
这里就需要用到ThreadLocal,在很多种Session 管理方案中都用到了它.ThreadLocal 是Java中一种较为特殊的线程绑定机制,通过ThreadLocal存取的数据,总是与当前线程相关,也就是说,JVM 为每个运行的线程,绑定了私有的本地实例存取空间,从而为多线程环境常出现的并发访问问题提供了一种隔离机制,ThreadLocal并不是线程本地化的实现,而是线程局部变量。
也就是说每个使用该变量的线程都必须为该变量提供一个副本,每个线程改变该变量的值仅仅是改变该副本的值,而不会影响其他线程的该变量的值,ThreadLocal是隔离多个线程的数据共享,不存在多个线程之间共享资源,因此不再需要对线程同步。
请看一下代码:
1. public class HibernateUtil {
2.
3. public static final SessionFactory sessionFactory;
4. public static final ThreadLocal session = new ThreadLocal();
5.
6. static{
7.
8. try{
9.
10. Configuration configuration=new Configuration().configure();
11. sessionFactory = configuration.buildSessionFactory();
12.
13. }catch (Throwable ex){
14.
15. System.err.println("Initial SessionFactory creation failed." + ex);
16. throw new ExceptionInInitializerError(ex);
17. }
18. }
19.
20. public static Session currentSession() throws HibernateException{
21. Session s = (Session) session.get();
22. if (s == null)
23. {
24. s = sessionFactory.openSession();
25. session.set(s);
26. }
27. return s;
28. }
29.
30. public static void closeSession() throws HibernateException {
31. Session s = (Session) session.get();
32. if (s != null)
33. s.close();
34. session.set(null);
35. }
36. }
以上介绍Hibernate Session。