一、Hibernate核心类和接口预览图
二、hibernate.properties
这个文件是以前老版本使用的,类似于hibernate.cfg.xml文件,作用和hibernate.cfg.xml一致。
三、hibernate.cfg.xml
(1)详细介绍
- 该文件主要用于指定各个参数,是hibernate核心文件
- 默认放在src目录下,也可以放在别的目录下
- 指定连接数据库的驱动、用户名、密码、url、连接池
- 指定对象关系映射文件的位置
- 也可使用hibernate.properties文件来替代该文件.(推荐使用hibernate.cfg.xml)。
(2)配置文件模板
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- 数据库连接设置 --> <property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property> <property name="connection.url">jdbc:sqlserver://127.0.0.1:1433;DatabaseName=hibernate</property> <property name="connection.username">sa</property> <property name="connection.password">123456</property> <!-- SQL方言,即明确告诉Hibernate连接的是哪种数据库 --> <property name="dialect">org.hibernate.dialect.SQLServerDialect</property> <!-- 二级缓存设置,这里是关闭 --> <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <!-- 显示对应的SQL语句 --> <property name="show_sql">true</property> <!-- 格式化输出SQL语句 --> <property name="format_sql">true</property> <!-- Drop and re-create the database schema on startup --> <!-- update和create的区别: create:每次先查询是否存在Student表,如果有则drop后再新建表,如果没有新建表 update:先查询是否存在Student表,如果有则更新数据(不会新建表,即使表结构发生变化),如果没有则新建表 --> <!-- <property name="hbm2ddl.auto">create</property> --> <property name="hbm2ddl.auto">update</property> <!-- 指定管理对象映射文件 --> <mapping resource="com/chongqing/hibernate/model/Student.hbm.xml"/> </session-factory> </hibernate-configuration>
四、*.hbm.xml
(1)对象关系映射文件(*.hbm.xml)
- 该文件主要作用是建立表和类的映射关系,是不可或缺的重要文件
- 一般放在其映射的类同一个目录下,但不是必须的
- 命名方式一般是 类名.hbm.xml,但不是必须的
- 示意图:
(2)配置文件模板
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.chongqing.hibernate.model"> <class name="Student" table="student"> <!-- id元素用于指定主键属性 --> <id name="id" column="id" type="java.lang.Integer"> <generator class="identity" /> </id> <!-- 对其他属性的配置 --> <property name="name" type="java.lang.String"> <column name="name" not-null="false" /> </property> <property name="age" type="java.lang.Integer"> <column name="age" not-null="false" /> </property> </class> </hibernate-mapping>
五、Configuration类
(1)详细介绍
- 负责管理hibernate的配置信息
- 读取hibernate.cfg.xml
- 加载hibernate.cfg.xml配置文件中配置的驱动,url,用户名,密码,连接池
- 管理 *.hbm.xml对象关系文件
(2)示意代码
//创建Configuration,该对象用于读取hibernate.cfg.xml配置文件,并完成初始化 configuration = new Configuration().configure();
六、SessionFactory(会话工厂)接口
(1)详细介绍
- 缓存sql语句和某些数据,它是重量级的
- 之所以称SessionFactory是重量级的,是因为它需要一个很大的缓存,用来存放预定义的SQL语句及映射元素等
- 在应用程序初始化的时候创建,是一个重量级的类(吃内存),一般用单例模式保证一个应用中只需要一个 SessionFactory实例
- 如果某个应用访问多个数据库,则要创建多个会话工厂实例,一般是一个数据库一个会话工厂实例
- 通过SessionFactory接口可以获得Session(会话)实例
(2)示意代码
//创建Configuration,该对象用于读取hibernate.cfg.xml配置文件,并完成初始化 configuration = new Configuration().configure(); //创建SessionFactory,一个SessionFactory对应一个数据存储源 sessionfactory = configuration.buildSessionFactory(); session = sessionfactory.openSession(); //或者session = sessionfactory.getCurrentSession();
七、Session(会话)接口
(1)接口介绍
- Session一个实例代表与数据库的一次操作(当然一次操作可以是crud组合)
- Session实例是轻量级的,所谓轻量级,是指它的创建和销毁不需要消耗太多的资源
- Session实例通过SessionFactory获取,用完需要关闭
- Session是线程不同步的(不安全),因此要保证在同一线程中使用,可以用getCurrentSessiong()
- Session可以看做是持久化管理器,它是与持久化操作相关的接口
(2)Session(会话)接口的几个重要方法
初识化过程结束后,就可以调用SessionFactory实例的openSession()方法来获得Session实例,然后通过它来执行访问数据库的操作。Session接口提供了操作数据库的各自方法,如下:
- 保存一个对象(记录)—save方法
- 删除一个对象(记录)—delete方法
- 查询一个对象(记录)—get/load方法
- 修改一个对象(记录)—update方法
八、Transaction(事务)接口
(1)事务接口
事务简单的说,就是一组对数据库的操作集合,它们要么全部成功,要么全部失败.这个可以保证数据的一致性,事务具有原子性。
- Transaction是底层的事物实现中抽象出来的接口
- 可能是一个jdbc或者jta的事务,这样有利于hibernate在不同执行环境的移植
- Hibernate要求显示的调用事务(如果仅仅是查询可以不调用)
try { session = sessionfactory.openSession(); ts = session.beginTransaction(); //do some work..... ts.commit(); } catch (Exception e) { e.printStackTrace(); if(ts!=null){ ts.rollback(); } }finally{ if(session!=null&&session.isOpen()){ session.close(); } }
(2)全局事务和本地事务
本地事务:针对一个数据库的事务(jabc事务);
全局事务:跨数据库的事务(jta事务);
九、Query接口
Query接口类型的对象可以对数据库操作,它可以使用HQL,Qbc,Qbe和原生SQL(native Sql)对数据库操作,官方推荐使用HQL语句。
Session session = null; Transaction ts = null; try { SessionFactory sessionfactory = MySessionFactory.getSessionFactory(); session = sessionfactory.openSession(); ts = session.beginTransaction(); //注意这里的Student不是表,而是domian类名 //where后面的条件即可以是表的字段名,也可以是domain类的属性,推荐使用类的属性名 Query query = (Query) session.createQuery("from Student where name='s1'"); //通过list方法获取结果,这个list会自动的封装成对应的domain对象 //所以不用对jdbc进行二次封装 List<Student> list = query.list(); for(Student s:list) { System.out.println("id="+s.getId()+"name="+s.getName()); } ts.commit(); } catch (Exception e) { e.printStackTrace(); if(ts!=null){ ts.rollback(); } }finally{ if(session!=null&&session.isOpen()){ session.close(); } }
十、 Criteria接口
Criteria接口也可用于面向对象方式的查询,Criteria一般用于条件查询
Session session = null; Transaction ts = null; try { SessionFactory sessionfactory = MySessionFactory.getSessionFactory(); session = sessionfactory.openSession(); ts = session.beginTransaction(); //查询 Criteria criteria = session.createCriteria(Student.class).setMaxResults(4); List<Student> list = criteria.list(); for(Student s:list) { System.out.println("id="+s.getId()+"name="+s.getName()); } ts.commit(); } catch (Exception e) { e.printStackTrace(); if(ts!=null){ ts.rollback(); } }finally{ if(session!=null&&session.isOpen()){ session.close(); } }