Hibernate

本文深入探讨了Hibernate开发过程中的关键接口及其作用,详细解释了初始化、SessionFactory、Session、Transaction和Query接口的工作原理,以及如何通过这些接口实现持久化操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值