全部的Hibernate应用中都会访问Hibernate的5个核心接口。 Configuration接口:配置Hibernate,根启动Hibernate,建立SessionFactory对象。 SessionFactory接口:初始化Hibernate,充当数据存储源的代理,建立Session对象。 Session接口:负责保存、更新、删除、加载和查询对象。 Transaction接口:管理事务。 Query和Criteria接口:执行数据库查询。 1.Configuration接口 Configuration对象用于配置而且启动Hibernate。Hibernate应用经过Configuration实例来指定对象-关系映射文件的位置或者动态配置Hibernate的属性,而后建立SessionFactory实例。 2.SessionFactory接口 一个SessionFactory实例对应一个数据存储源,应用从SessionFactory中得到Session实例。SessionFactory有如下特色: 它是线程安全的,这意味着它的同一个实例能够被应用的多个线程共享。 它是重量级的,这意味着不能随意建立或销毁它的实例。若是应用只访问一个数据库,只须要建立一个SessionFactory实例,在应用初始化的时候建立该实例。若是应用同时访问多个数据库,则须要为每一个数据库建立一个单独的SessionFactory实例。 之因此称SessionFactory是重量级的,是由于它须要一个很大的缓存,用来存放预约义的SQL语句以能映射元数据等。用户还能够为SesionFactory配置一个缓存插件,这个缓存插件被称为Hibernate的第二级缓存。,该缓存用来存放被工做单元读过的数据,未来其余工做单元可能会重用这些数据,所以这个缓存中的数据可以被全部工做单元共享。一个工做单元一般对应一个数据库事务。 3.Session接口 Session接口是Hibernate应用使用最普遍的接口。Session也被称为持久化管理器,它提供了和持久化相关的操做,如添加、更新、删除、加载和查询对象。 Session有如下特色: 不是线程安全的,所以在设计软件架构时,应该避免多个线程共享同一个Session实例。 Session实例是轻量级的,所谓轻量级,是指它的建立和销毁不须要消耗太多的资源。这意味着在程序中能够常常建立和销毁Session对象,例如为每一个客户请示分配单独的Session实例,或者为每一个工做单元分配单独的Session实例。 Session有一个缓存,被称为Hibernate的第一级缓存,它存放被当前工做单元加载的对象。每一个Session实例都有本身的缓存,这个Sesion实例的缓存只能被当前工做单元访问。 4.Transaction接口 Transaction接口是Hibernate的数据库事务接口,它对底层的事务接口作了封装,底层事务接口包括: JDBC API、JTA(Java Transaction API)、CORBA(Common Object Requet Broker Architecture)API Hibernate应用可经过一致的Transaction接口来声明事务边界,这有助于应用在不一样的环境容器中移植。尽管应用也能够绕过Transaction接口,直接访问底层的事务接口,这种方法不值得推荐,由于它不利于应用在不一样的环境移植。 5.Query和Criteria接口 Query和Criteria接口是Hibernate的查询接口,用于向数据库查询对象,以及控制执行查询的过程。Query实例包装了一个HQL查询语句,HQL查询语句和SQL查询语句有些类似,但HQL查询语句是面向对象的,它引用类句及类的属性句,而不是表句及表的字段句。Criteria接口彻底封装了基于字符串的查询语句,比Query接口更加面向对象,Criteria接口擅长执行动态查询。 Session接口的find()方法也具备数据查询功能,但它只是执行一些简单的HQL查询语句的快捷方法,它的功能远没有Query接口强大。