Hibernate框架原理及使用

简介: Hibernate实现了面向对象的方式进行数据库操作,是对JDBC进行轻量级封装的成果,方法是将POJO对象和数据库表建立关系。简单的来说,使用Hibernate之后,操作数据库就不需要像之前的JDBC那样进行复杂的操作了。 使用hibernate的好处是: 1、更加对象化,以对象化的思维操作数据库,我们只需要操作对象就可以了,开发更加对象化,符合Java面向对象的思想。2、移植性高,

Hibernate实现了面向对象的方式进行数据库操作,是对JDBC进行轻量级封装的成果,方法是将POJO对象和数据库表建立关系。简单的来说,使用Hibernate之后,操作数据库就不需要像之前的JDBC那样进行复杂的操作了。

使用hibernate的好处是:

1、更加对象化,以对象化的思维操作数据库,我们只需要操作对象就可以了,开发更加对象化,符合Java面向对象的思想。
2、移植性高,因为Hibernate做了持久层的封装,不直接操作数据库,所有的代码都具有可复用性。
3、Hibernate是一个没有侵入性的框架,没有侵入性的框架我们称为轻量级框架。对比Struts的Action和ActionForm,都需要继承,离不开Struts。Hibernate不需要继承任何类,不需要实现任何接口。

Hibernate实体类中有三种状态:

瞬时状态:使用new刚刚创建,还没有被持久化,且不处于session的缓存中
持久状态:已经被持久化了,而且加入到了Session的缓存中
游离状态:已经被持久化了,但是不再处于Session的缓存中

那么如何使用Hibernate呢?

配置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">

<!-- Generated by MyEclipse Hibernate Tools.                   -->
<hibernate-configuration>

    <session-factory>
        <property name="dialect">org.hibernate.dialect.Oracle9Dialect</property>
        <property name="connection.url">jdbc:oracle:thin:@603-4:1521:orcl</property>
        <property name="connection.username">root</property>
        <property name="connection.password">root</property>
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        <property name="myeclipse.connection.profile">mydriver</property>
    
    </session-factory>

</hibernate-configuration>
配置*.hbm.xml映射文件,也就是POJO和Table的映射:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.pojo.Dh12Info" table="STU_INFO" schema="xxx">
        <id name="SId" type="java.lang.Long"> 此ID为类中的属性
            <column name="S_ID" precision="30" scale="0" />--此处的ID是表中的字段
            <generator class="sequence" /> --ID的生成策略是sequence进行
        </id>
        <property name="SName" type="java.lang.String"> --实体列
            <column name="S_NAME" length="30" /> -- 表中的字段
        </property>
        <property name="SSex" type="java.lang.Integer">
            <column name="S_SEX" precision="1" scale="0" />
        </property>
        <property name="SBri" type="java.util.Date">
            <column name="S_BRI" length="7" />
        </property>
        <property name="SAdd" type="java.lang.String">
            <column name="S_ADD" length="500" />
        </property>
        <property name="STel" type="java.lang.String">
            <column name="S_TEL" length="15" />
        </property>
        <property name="SQq" type="java.lang.String">
            <column name="S_QQ" length="30" />
        </property>
    </class>
</hibernate-mapping>

使用Hibernate操作数据的流程是:

读取并解析配置文件 -----读取并解析映射文件,创建SessionFactory------打开session-------开启一个事务-------操作数据库--------提交或者回滚事务-------关闭session。

下面用一个例子来展示如何操作数据库:

public class AddTest extends TestCase {
	Configuration conf = null;
	SessionFactory sessionFactory = null;
	Session session = null;
	Transaction tran = null;
	protected void setUp() throws Exception {
		//完成1234步骤
		//第一步:读取并解析配置文件
		conf = new Configuration().configure();
		//第二步:读取并解析映射文件
		sessionFactory = conf.buildSessionFactory();
		//第三步:打开session
		session = sessionFactory.openSession();
		//第四步:开启一个事务
		tran = session.beginTransaction();
	}
	protected void tearDown() throws Exception {
		//完成7步骤
		//第七步:关闭回话
		session.close();
	}
	public void add(){
		//真正完成数据库的操作
		StuInfo pojo = new StuInfo("张三",1,new Date(),"山西省太原市","137227839","5445567858");
		try {
			session.save(pojo);
			tran.commit();//提交
		} catch (Exception e) {
			tran.rollback();
			e.printStackTrace();
			// TODO: handle exception
		}
	}

}
使用Hibernate,少量的代码便实现了数据的插入 ,session.save(pojo);,是对SQL的封装,实现插入数据。

对于修改和删除来说,我们要先进行数据库查询操作:使用Hibernate实现数据库的查询操作,Session中提供了两种的加载数据的方式
Object get(Class c,id):通过ID加载数据,返回实体类对象,使用get加载数据的时候,如果数据不存在则返回null
Object load(Class c ,id): 通过ID加载数据,返回实体类对象,如果数据不存在,则会抛出异常

如下:

public void update(){
		//真正完成数据库的操作
		StuInfo pojo = (StuInfo)session.get(StuInfo.class,new Long(1));
		pojo.setSName("李四");
		try {
			session.update(pojo);
			tran.commit();//提交
		} catch (Exception e) {
			tran.rollback();
			e.printStackTrace();
			// TODO: handle exception
		}
	}

删除操作同理:

public void delete(){
		StuInfo pojo = (StuInfo)session.get(StuInfo.class,new Long(1));
		try {
			session.delete(pojo);//删除
			tran.commit();//提交
		} catch (Exception e) {
			tran.rollback();
			e.printStackTrace();
			// TODO: handle exception
		}
	}

以上就是对数据进行增删改查的方法。(提示)本例中没有使用main方法,而是使用Junit单元测试,所以要导入相应的包。





目录
相关文章
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
235 1
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
261 1
|
SQL XML 存储
Hibernate框架【五】——基本映射——多对多映射
Hibernate框架【五】——基本映射——多对多映射
376 0
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
498 0
|
SQL Java 数据库连接
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
228 1
|
SQL Java 关系型数据库
数据库访问:什么是Hibernate框架?
【4月更文挑战第15天】Hibernate是开源ORM框架,将Java对象与数据库表映射,简化对象-关系映射,提升开发效率和性能。它自动化处理数据操作,支持多种数据库,自动生成SQL,提供配置选项和高级特性,减少手动SQL编写,便于切换数据库。
188 2
|
Java 数据库连接 数据库
探索JPA生态:Hibernate与其他ORM框架的对比分析
【6月更文挑战第25天】**JPA标准下的Hibernate是流行的ORM实现,提供丰富功能如二级缓存和延迟加载,但其学习曲线较陡,性能优化复杂。相比如MyBatis,Hibernate的JPQL更面向对象,MyBatis则接近SQL。选择ORM需考虑项目需求和个人偏好。**
267 0
|
Java 数据库连接
杨老师课堂之JavaEE三大框架Hibernate入门第一课
杨老师课堂之JavaEE三大框架Hibernate入门第一课
124 0