博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate的Session上下文形式
阅读量:4178 次
发布时间:2019-05-26

本文共 819 字,大约阅读时间需要 2 分钟。

Hibernate的Session对象的有效范围与创建其的上下文有关。不过,在整个应用的生命周期中,却可能存在不同的上下文。

1. 在Hibernate 3.0之前,应用中的上下文都是基于代理/拦截器的,如下:

  • 通过ThreadLocal生成的上下文,如HibernateUtil类生成的上下文
  • 通过第三方框架生成的上下文,如Spring或Pico框架生成的上下文

2. 从Hibernate 3.0.1开始,为了支持JTA事务,Hibernate提供了SessionFactory.getCurrentSession()方法。

3. 从Hibernate 3.1开始,SessionFactory.getCurrentSession()方法的执行变成了可插入的,这是通过如下机制实现:

1) SPI接口org.hibernate.context.spi.CurrentSessionContext

唯一定义currentSession()方法
2) Hibernate 3.1提供了接口org.hibernate.context.spi.CurrentSessionContext的3个实现

    • org.hibernate.context.internal.ThreadLocalSessionContext
    • org.hibernate.context.internal.JTASessionContext
    • org.hibernate.context.internal.ManagedSessionContext

3) 配置参数hibernate.current_session_context_class=thread|jta|managed

给出接口org.hibernate.context.spi.CurrentSessionContext的实现类的别名

上述不同的上下文决定了Session对象的使用方式,我们将在后续文章中介绍。

转载地址:http://qilai.baihongyu.com/

你可能感兴趣的文章
面试题31-------连续子数组的最大和(数组)
查看>>
epoll 实现Chat
查看>>
21. Merge Two Sorted Lists(链表)
查看>>
2. Add Two Numbers(链表)
查看>>
637. Average of Levels in Binary Tree(Tree)
查看>>
226. Invert Binary Tree(Tree)
查看>>
328. Odd Even Linked List(链表)
查看>>
617. Merge Two Binary Trees(Tree)
查看>>
700. Search in a Binary Search Tree(Tree)
查看>>
515. Find Largest Value in Each Tree Row(Tree)
查看>>
897. Increasing Order Search Tree(Tree)
查看>>
199. Binary Tree Right Side View(Tree)
查看>>
230. Kth Smallest Element in a BST(Tree)
查看>>
求字符串的最长回文串-----Manacher's Algorithm 马拉车算法
查看>>
回溯法常用的解题模板和常见题型
查看>>
深入分析Java I/O 的工作机制
查看>>
动态规划的套路----左神
查看>>
KMP算法简解
查看>>
左神算法课进阶版总结
查看>>
左神算法基础班总结
查看>>