现在的位置: 首页 > 综合 > 正文

详解Hibernate Session

2018年01月25日 ⁄ 综合 ⁄ 共 2814字 ⁄ 字号 评论关闭

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. }  

以上介绍Hibernate Session。

HIbernate中的Session
  Session是JAVA应用程序和Hibernate进行交互时使用的主要接口,它也是持久化操作核心API, 
  注意这里的Session的含义,它与传统意思上web层的HttpSession并没有关系,Hibernate Session之与Hibernate,相当于JDBC Connection相对与JDBC。 
  Session对象是有生命周期的,它以Transaction对象的事务开始和结束边界 
  Session作为贯穿Hibernate的持久化管理器核心,提供了众多的持久化的方法,如save(), update ,delete ,find(Hibernate 3中已经取消了此方法)等,通过这些方法我们可以透明的完成对象的增删改查(CRUD-- create read update delete),这里所谓的透明是指,Session在读取,创建和删除影射的实体对象的实例时,这一系列的操作将被转换为对数据库表中数据的增加,修改,查询和删除操作。

       SessionFactory负责创建Session,SessionFactory是线程安全的,多个并发线程可以同时访问一个SessionFactory 并从中获取Session实例。而Session并非线程安全,也就是说,如果多个线程同时使用一个Session实例进行数据存取,则将会导致Session 数据存取逻辑混乱.因此创建的Session实例必须在本地存取空上运行,使之总与当前的线程相关。


Session有以下的特点
  1,不是线程安全的,应该避免多个线程共享同一个Session实例 
  2,Session实例是轻量级的,所谓轻量级:是指他的创建和删除不需要消耗太多资源 
  3,Session对象内部有一个缓存,被称为Hibernate第一缓存,他存放被当前工作单元中加载的对象,每个Session实例都有自己的缓存。

Hibernate Session缓存被称为Hibernate的第一级缓存。SessionFactory的外置缓存称为Hibernate的二级缓存。这两个缓存都位于持久层,它们存放的都是数据库数据的拷贝。SessionFactory的内置缓存 存放元数据和预定义SQL, SessionFactory的内置缓存是只读缓存。

Hibernate Session缓存的三大作用:
1,减少数据库的访问频率,提高访问性能。
2,保证缓存中的对象与数据库同步,位于缓存中的对象称为持久化对象。
3,当持久化对象之间存在关联时,Session 保证不出现对象图的死锁。
Session 如何判断持久化对象的状态的改变呢?
Session 加载对象后会为对象值类型的属性复制一份快照。当Session 清理缓存时,比较当前对象和它的快照就可以知道那些属性发生了变化。

Session 什么时候清理缓存?
1,commit() 方法被调用时
2,查询时会清理缓存,保证查询结果能反映对象的最新状态。
3,显示的调用session 的 flush方法。
session 清理缓存的特例:
当对象使用 native 生成器 时 会立刻清理缓存向数据库中插入记录。

抱歉!评论已关闭.