Hibernate的核心组件
在基于MVC设计模式的JAVA WEB应用中,Hibernate可以作为模型层/数据访问层。它通过配置文件(hibernate.properties或hibernate.cfg.xml)和映射文件(***.hbm.xml)把JAVA对象或PO(Persistent Object,持久化对象)映射到数据库中的数据库,然后通过操作PO,对数据表中的数据进行增,删,改,查等操作。
除配置文件,映射文件和持久化类外,Hibernate的核心组件包括以下几部分:
a)Configuration类:用来读取Hibernate配置文件,并生成SessionFactory对象。
b)SessionFactory接口:产生Session实例工厂。
c)Session接口:用来操作PO。它有get(),load(),save(),update()和delete()等方法用来对PO进行加载,保存,更新及删除等操作。它是Hibernate的核心接口。
d)Query接口:用来对PO进行查询操。它可以从Session的createQuery()方法生成。
e)Transaction接口:用来管理Hibernate事务,它主要方法有commit()和rollback(),可以从Session的beginTrancation()方法生成。
Persistent Object
持久化对象可以是普通的Javabeans,惟一特殊的是它们与(仅一个)Session相关联。JavaBeans在Hibernate中存在三种状态:
1.临时状态(transient):当一个JavaBean对象在内存中孤立存在,不与数据库中的数据有任何关联关系时,那么这个JavaBeans对象就称为临时对象(Transient Object)。
2.持久化状态(persistent):当一个JavaBean对象与一个Session相关联时,就变成持久化对象(Persistent Object)
3.脱管状态(detached):在这个Session被关闭的同时,这个对象也会脱离持久化状态,就变成脱管状态(Detached Object),可以被应用程序的任何层自由使用,例如可以做与表示层打交道的数据舆对象(Data Transfer Object)。
Hibernate的运行过程
Hibernate的运行过程如下:
A:应用程序先调用Configration类,该类读取Hibernate的配置文件及映射文件中的信息,并用这些信息生成一个SessionFactpry对象。
B:然后从SessionFactory对象生成一个Session对象,并用Session对象生成Transaction对象;可通过Session对象的get(),load(),save(),update(),delete()和saveOrUpdate()等方法对PO进行加载,保存,更新,删除等操作;在查询的情况下,可通过Session对象生成一个Query对象,然后利用Query对象执行查询操作;如果没有异常,Transaction对象将 提交这些操作结果到数据库中。
Hibernate的运行过程如下图:
data:image/s3,"s3://crabby-images/1ae61/1ae6175593e94a27646119a071b53cc5958c5bc4" alt="技术分享"
Hibernate简单示例:
数据:
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
create table T_register
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
(
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
id int primary key,
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
userName varchar(30),
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
userPwd varchar(30),
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
sex varchar(10),
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
age int
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
)
视图层:注册页面register.jsp
设计持久化类TRegister.java
data:image/s3,"s3://crabby-images/50228/5022881bcb02ad0ae153a70a3f27a1b2c1ffd1c7" alt="技术分享"
package hibernate.PO;
/**
* 持久化类
*/
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
public class TRegister implements java.io.Serializable {
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
// Fields
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
private Integer id;
private String userName;
private String userPwd;
private String sex;
private Integer age;
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
// Constructors
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
/** default constructor */
public TRegister() {
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
/** minimal constructor */
public TRegister(Integer id) {
this.id = id;
}
/** full constructor */
public TRegister(Integer id, String userName, String userPwd, String sex, Integer age) {
this.id = id;
this.userName = userName;
this.userPwd = userPwd;
this.sex = sex;
this.age = age;
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
// Property accessors
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
public String getUserName() {
return this.userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
public String getUserPwd() {
return this.userPwd;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
public String getSex() {
return this.sex;
}
public void setSex(String sex) {
this.sex = sex;
}
data:image/s3,"s3://crabby-images/bec20/bec20b334f0a53487debda7dda10e0c7c8ee98f4" alt="技术分享"
public Integer getAge() {
return this.age;
}
public void setAge(Integer age) {
this.age = age;
}
}
设计Hibernate配置文件hibernate.cfg.xml
data:image/s3,"s3://crabby-images/50228/5022881bcb02ad0ae153a70a3f27a1b2c1ffd1c7" alt="技术分享"
<?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">
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
<session-factory>
<property name="connection.username">root</property>
<property name="connection.url">
jdbc:mysql://localhost:3306/study
</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="myeclipse.connection.profile">MySQL5.0</property>
<property name="connection.password">root</property>
<property name="connection.driver_class">
org.gjt.mm.mysql.Driver
</property>
<property name="show_sql">true</property>
<mapping resource="hibernate/PO/TRegister.hbm.xml" />
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
</session-factory>
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
</hibernate-configuration>
设计映射文件TRegister.hbm.xml
data:image/s3,"s3://crabby-images/50228/5022881bcb02ad0ae153a70a3f27a1b2c1ffd1c7" alt="技术分享"
<?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 - Hibernate Tools
-->
<hibernate-mapping>
<class name="hibernate.PO.TRegister" table="t_register">
<id name="id" type="java.lang.Integer">
<column name="id" />
<!-- 我在MYSQL中并没有设置该字段递增,但在Hibernate中依然可以设置为递增 -->
<generator class="increment" />
</id>
<property name="userName" type="java.lang.String">
<column name="userName" length="30" />
</property>
<property name="userPwd" type="java.lang.String">
<column name="userPwd" length="30" />
</property>
<property name="sex" type="java.lang.String">
<column name="sex" length="10" />
</property>
<property name="age" type="java.lang.Integer">
<column name="age" />
</property>
</class>
</hibernate-mapping>
data:image/s3,"s3://crabby-images/d418f/d418fe3c8aa7962fd69a93eac48842e432bcd37c" alt="技术分享"
设计hibernate基础类HibernateUtil.java
设计控制类