经过一个星期的Hibernate学习,我自己也有一些体会。
没有接触Hibernate之前,对于JDBC是深恶痛绝的。JDBC无法直接面向对象,开发效率低,代码冗余,重复性工作太多等等。编程也是讲效率的,过多的冗余代码,太多的重复性工作使其效率低下。然而,Hibernate却不一样,它是一种开放源代码的关系映射框架,它对JDBC进行了轻量级的对象封装,大大减少的代码的冗余,减少了各种重复性工作。
既然Hibernate有那么多优点,那么怎样学习它才能更有效率呢?我觉得应该从以下几个方面。
1.对象与数据库之间的关系。在Hibernate中,我们需要建立一种映射,即实体类与表的映射,属性与表中字段的映射,最后是属性和主键的映射。 但是,表之间只能通过外键来表示关联关系。其它关系都是借助hibernate的配置来实现的。
2.Hibernate中有几个核心接口,configuration(配置)、session(回话)、sessionfactory(会话工厂)、Query(查询)、Transaction(事务)。对于数据库的操作,一般的顺序是读取configuration,创建工厂,打开,开始事务,进行数据库操作,提交事务,最后关闭。
3.Hibernate中实体对象的三种状态:1)瞬时状态(Transient)刚用new语句创建,还没有被持久化,且不处于Session的缓存中2)持久状态(Persistent)已经被持久化,且加入到Session的缓存中3)游离状态(Detached)已经被持久化,但不再处于Session的缓存中.
4
.关系映射。
除了将实体与表进行映射之外,还要将实体的关联关系与表的关联关系进行映射。有以下几种关系映射,(1)单向多对一
映射
(2)单向一对多映射:
(3)多对多映射,我们只需要把它看成两个一对多就行了。
5.HQL的应用,我觉得只要掌握使用HQL的四个步骤就行了.得到Session,编写HQL语句,创建Query,执行查询得到结果。其实Hql和sql表面很像,但是,本质是不同的,Hql是面向对象的查询。
6.除了HQL,我又接触了Criteria,HQL的查询功能都能用Criteria实现,不同的是HQL查询时基于字符串的,因此相对灵活。另外Criteria的语法和HQL不尽相同,总体感觉,更符合面向对象的思想。
7.Hibernate高速缓存,这部分有难度,Hibernate一级缓存的生命周期跟Session的生命周期一样,所以也可以将Hibernate一级缓存称为Session缓存。Hibernate一级缓存是一个强制的高速缓存。get()方法会去一级缓存中查找获取数据(又称命中数据),并且将查询结果放置在一级缓存中。load()也一样。对于二级缓存,二级缓存是一个可选的缓存插件,它由SessionFactory负责管理,所以也常将二级缓存称为SessionFactory缓存。由于SessionFactory对象的生命周期和应用程序的整个过程对应,因此二级缓存是进程范围的缓存,可以被线程共享,所以可能存在并发问题,因此需要采用适当的并发访问策略。二级缓存对实体类是可选的,可以在每个类或每个集合的粒度上配置二级缓存。Hibernate的二级缓存策略,是针对于id查询的缓存策略,对于条件查询则毫无作用。