码迷,mamicode.com
首页 > Web开发 > 详细

Hibernate工作原理及为什么要用?

时间:2015-05-25 22:36:50      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:hibernate   事务   缓存机制   优化   

Hibernate工作原理及为什么要用?
 
原理:
 
1. 读取并解析配置文件
 2. 读取并解析映射信息,创建SessionFactory
 3. 打开Sesssion
 4. 创建事务Transation
 5. 持久化操作
 6. 提交事务
 7. 关闭Session
 8. 关闭SesstionFactory
 
为什么要用:
 
* 对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。
 * Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现。他很大程度的简化DAO层的编码工作
 * hibernate使用Java反射机制,而不是字节码增强程序来实现透明性。
 * hibernate的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。
 
Hibernate是如何延迟加载?
 
* Hibernate2延迟加载实现:a)实体对象 b)集合(Collection)
 * Hibernate3 提供了属性的延迟加载功能
 
当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内存开销,从而提高了服务器的性能。
 Hibernate中怎样实现类之间的关系?(如:一对多、多对多的关系)
 类与类之间的关系主要体现在表与表之间的关系进行操作,它们都市对对象进行操作,我们程序中把所有的表与类都映射在一起,它们通过配置文件中的many-to-one、one-to-many、many-to-many、
 
说下Hibernate的缓存机制
 
* 内部缓存存在Hibernate中又叫一级缓存,属于应用事物级缓存
 * 二级缓存:
 
a)应用及缓存
 
b)分布式缓存
 
条件:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被系统频繁使用、非 关键数据
 
c) 第三方缓存的实现
 Hibernate的查询方式
 Sql、Criteria,object comptosition
 Hql:
 
* 属性查询
 * 参数查询、命名参数查询
 * 关联查询
 * 分页查询
 * 统计函数
 
如何优化Hibernate?
 
* 使用双向一对多关联,不使用单向一对多
 * 灵活使用单向一对多关联
 * 不用一对一,用多对一取代
 * 配置对象缓存,不使用集合缓存
 * 一对多集合使用Bag,多对多集合使用Set
 * 继承类使用显式多态
 * 表字段要少,表关联不要怕多,有二级缓存撑腰

Hibernate工作原理及为什么要用?

标签:hibernate   事务   缓存机制   优化   

原文地址:http://blog.csdn.net/s2940086379/article/details/45972341

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!