Hibernate框架原理及使用

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单元测试,所以要导入相应的包。

时间: 2024-09-30 01:58:45

Hibernate框架原理及使用的相关文章

【mybatis深度历险系列】mybatis的框架原理+入门程序解析

在前面的博文中,小编介绍了springmvc的相关知识点,在今天这篇博文中,小编将介绍一下mybatis的框架原理,以及mybatis的入门程序,实现用户的增删改查,她有什么优缺点以及mybatis和hibernate之间存在着怎么样的关系,接下来小编一一进行讲解,希望对小伙伴们有帮助,不足之处,还请多多指教. 什么是mybatis? MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google co

hibernate中用annotation注解怎么样配置TIMESTAMP类型的数据呢

问题描述 请问hibernate中用annotation注解怎么样配置TIMESTAMP类型的数据并且能自动插入和更新呢?就是相当于mysql中timeTIMESTAMPDEFAULTCURRENT_TIMESTAMPONUPDATECURRENT_TIMESTAMP;这样的数据列,在hibernate中怎么样用annotation注解来配置呢(不要xml的配置方式).各位大虾帮帮忙啊,跪求中-- 解决方案 解决方案二:没用过注解吖.看下这个资料吧解决方案三:@Column(name="D_UP

混合Eclipse、WTP、Struts和Hibernate

使用Eclipse Web Tools Project.Tomcat应用服务器和MySQL数据库服务器,创建了一个Web应用程序.尽管该应用程序(DBTest)可能会很不错,但是也会存在一些局限性: 在servlet代码中,Java Server Pages (JSP) 名称是硬编码的 SQL也被硬编码到命令类中. 幸运的是,这些问题可以通过两种有趣的解决方案得以解决.第一个问题可通过使用开源Struts框架解决,该框架通过将模型动作映射到一个简单配置文件中的视图组件(比如JSP),从而分离应用

系统学习hibernate之三 transient、persistent、detached状态

transient.persistent.detached状态关系图如下: 1.transient状态的特征: * 在数据库中没有与之匹配的数据 * 没有纳入session的管理 2.persistent状态的特征: * persistent状态的对象在数据库中有与之匹配的数据 * 纳入了session的管理 * 在清理缓存(脏数据检查)的时候,会和数据库同步 3.detached状态的特征: * 在数据库中有与之匹配的数据 * 没有纳入session的管理 PS:了解这几种状态对深入使用hib

Hibernate流行架构浅析

本文向大家介绍Hibernate架构,可能好多人还不了解Hibernate架构,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西. 用java来建立一个很有价值的web 应用不是一个简单的任务.在架构这个应用时要考虑很多的因素和问题.从更高的层次来看,开发人员面临着关于如何构建用户接口,何处驻留业务逻辑,以及如何实现数据持久性这些问题.这3层都有各自的问题需要回答.而每一层又需要实现那些技术?应用如何设计来进行松散耦合并能进行灵活变更?应用架构是否允许某一层变更而不影响到其它的层次?

Unitils+hibernate+Spring+PostgreSql做dao层测试遇到的错误

这两天看陈雄华的书<Spring3.0企业开发实战>17章做dao层的测试,由于使用postgreSql数据库,所以遇到了不少错误,很多问题百度都没找到答案,所以记录下来给遇到同样错误的童鞋做个参考.下面是我遇到的问题: 1.unitils目前还不支持Hibernate4,所以使用hibernate4的童鞋,要么换hibernate3要么自己用dbUnit做测试. 2.org.unitils.core.UnitilsException: Missing configuration for or

Java Persistence with Hibernate中文版Hibernate实战第2版出版

Java Persistence with Hibernate中文版Hibernate实战第2版出版 图灵出版社官方Hibernate实战(第2版)链接为: http://www.turingbook.com/Books/ShowBook.aspx?BookID=260 书 名: Hibernate实战(第2版) 评论星级: **** 书 号: 978-7-115-17448-2 原 书 名: Java Persistence with Hibernate 原出版社: Manning Publi

org.hibernate.PropertyAccessException: Null value was assigned to a property of primitive type setter of com.*.Paper.totalTime

at org.hibernate.property.BasicPropertyAccessor$BasicSetter.set(BasicPropertyAccessor.java:109) at org.hibernate.tuple.entity.AbstractEntityTuplizer.setPropertyValues(AbstractEntityTuplizer.java:586) at org.hibernate.tuple.entity.PojoEntityTuplizer.s

s2sh框架整合,hibernate无法执行删除问题

问题描述 s2sh框架整合,hibernate无法执行删除问题 dao层的代码 public void deleteDepartment(Serializable id,String delMode) { Department department=this.getDepartmentById(id); //通过页面出来的参书id,获得 这个对象 if("del_pre_relation".equals(delMode)){ Set users = department.getUser