C3P0数据库连接池的配置
第一个配置是告诉Hibernate使用什么数据库连接池,之后的配置参数一看就知道是什么意思没必要解释,但是配置的参数并不是最优的,要视实际情况而定。
======================================================================
======================================================================
SessionFactory的二级缓存机制
一级缓存Session:其实Session的缓存机制并不能提高多大的效率,只是为了管理对象而已。因为每次Session的生命周期都很短,打开一会儿就关闭。
二级缓存SessionFactory:
使用二级缓存的步骤:
默认情况下Hibernate是不开启二级缓存的。
1.在cfg.xml文件中配置启动二级缓存
设置hibernate.cache.provider_class属性,指定其他的缓存策略, 该缓存策略必须实现org.hibernate.cache.CacheProvider接口
有很多的缓存策咯提供商:比如ehcache、oscache、jbosscache,我们主要使用EHcache
这些缓存jar包在Hibernate的lib 包下的可选jar包中有。
二级缓存分为:
类级别配置:
属性级别配置(通常指的是集合关联属性):
不管是一级缓存还是二级缓存都得在使用OID获取对象时才有效。(get or load)
对于Query.list()默认不使用缓存,即使写成where id=xx.也不会使用
如何理解二级缓存:SessionFactory是生产Session的工厂,里面的内存比Session大很多,里面能存储Session缓存过的东西,而每个Session之间是独立的,缓存的数据并不能共享,所以就产生了可以缓存所有Session里面的缓存数据的容器即SessionFactory.
摘录人家的一段话:
“不要想当然的以为缓存一定能提高性能,仅仅在你能够驾驭它并且条件合适的情况下才是这样的。hibernate的二级缓存限制还是比较多的,不方便用jdbc可能会大大的降低更新性能。在不了解原理的情况下乱用,可能会有1+N的问题。不当的使用还可能导致读出脏数据。 如果受不了hibernate的诸多限制,那么还是自己在应用程序的层面上做缓存吧。
在越高的层面上做缓存,效果就会越好。就好像尽管磁盘有缓存,数据库还是要实现自己的缓存,尽管数据库有缓存,咱们的应用程序还是要做缓存。因为底层的缓存它并不知道高层要用这些数据干什么,只能做的比较通用,而高层可以有针对性的实现缓存,所以在更高的级别上做缓存,效果也要好些吧。”
Hibenate总结:
1.hibernate.cfg.xml 和 hbm.xml配置文件非常重要
2.关联映射(一对多和多对一还有一对一)
2.Session接口的方法和操作,Query接口
3.一级二级缓存机制
4.Hibernate框架的性能优化(配置数据库连接池、缓存策咯)
在使用集成Struts2.x 和Hibernate3.6之后版本最好增加如下属性
1.搭建Hibernate的开发环境(jar、hibernate.cfg.xml、hbm.xml)
2.hibernate.cfg.xml的配置
*连接数据库的基本信息
*配置c3p0数据源的基本信息
*配置Hibernate的基本信息
*导入映射文件
3.映射文件:重点在于关联关系的映射还有一些常用配置比如懒加载之类的
*一对多与多队一的关联映射
*一对一的关联映射
4.Session对象的主要方法(研究API和源码)
5.Query对象的主要方法(研究API和源码)
6.对象的几种状态之间的转换 Session的一级缓存机制以及SessionFactory二级缓存机制
7.对于一级和二级缓存的理解
8.HQL查询语言(类似sql只是把table 换成类,把字段换成了属性而已)