Hibernate

来源:互联网 发布:手机同声翻译软件 编辑:程序博客网 时间:2024/05/24 02:29

Hibernate开发过程中会用到5个核心接口,分别为:Configuration接口、SessionFactory接口、Session接口、Transaction接口和用于数据查询的Query接口。通过这些接口,可以对持久化对象进行操作,还可以进行事务控制。Hibernate就是通过这个接口来进行持久化工作的。

工作原理:

一、Hibernate的初始化,创建Configuration对象。

这一步用来读取XML配置文件和映射文件的信息到Configuration对象的属性中。具体为:

1、从Hibernate配置文件Hibernate.cfg.xml中读取配置信息,存放到Configuration对象(内存)中。

2、根据配置文件中的mapping元素加载所有实体类对应的映射文件到Configuration对象中。

二、创建SessionFactory实例。

通过Configuration对象读取到的配置文件信息创建SessionFactory,即将Configuration对象内的配置信息存入SessionFactory的内存(属性)中。SessionFactory充当数据存储源的代理,并创建Session对象。得到SessionFactory对象后,Configuration对象的就结束了。

三、创建Session实例,建立数据库连接。

Session通过SessionFactory打开,创建一个Session对象就相当于与数据库建立了一个新的连接。Session对象用来操作实体对象,并把这些操作转换成对数据库中数据的增加、删除、查询和修改操作。

四、创建Transaction实例,开始一个事务。

Transaction用于事务管理,一个Transaction对象对应的事务可以包括多个操作。在使用Hivernate进行增加、删除和修改操作时必须先创建Transaction对象。

五、利用Session的方法进行持久化操作。将实体对象持久化到数据库中。

六、提交操作结果并结束事务。对实体对象的持久化操作结束后,必须提交事务。

七、关闭Session,与数据库断开连接。


Configuration类的作用是对Hibernate进行配置、启动Hibernate并连接数据库系统。

SessionFactory接口负责Hibernate的初始化。它作为数据存储源的代理,负责建立Session对象。【通常情况下,一个应用程序中只有一个SessionFactory实例,且该SessionFactory实例是不能改变的】

Session接口是持久化操作的核心。Session对象的生命周期以Transaction对象的事务开始和结束为边界。

Session提供了一系列与持久化相关的操作,如读取、创建和删除相关实体对象的实例,这一系列的操作最终将被转换为对数据库数据的增加、修改、查询和删除操作。【Hibernate的第一级缓存】

Trancation接口主要用于管理事务,是Hibernate的数据库事务接口,它对底层的事务接口进行了封装。【常用操作有事务提交和事务回滚】

Query接口是Hibernate的查询接口,用于向数据库中查询对象,并控制执行查询的过程。【它包装了一个HQL查询语句,采用了面向对象的查询方式】

Criteria接口与Query接口非常类似,也是 Hibernate的查询接口,它允许创建并执行面向对象方式的查询。

Criteria查询通过面向对象的设计,将数据查询条件封闭为一个对象。


配置文件hibernate.cfg.xml

<?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="dialect">org.hibernate.dialect.MySQLDialect</property><property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property><span style="white-space:pre"></span><property name="hibernate.connection.url">jdbc:mysql://localhost:3306/<span style="color:#ff0000;">数据库名</span></property><property name="hibernate.connection.username">root</property><property name="hibernate.connection.password">123</property> <property name="hbm2ddl.auto">update</property><property name="show_sql">true</property><mapping resource="bean/User.hbm.xml"/></session-factory></hibernate-configuration>

0 0