Hibernate的核心組件
在基于MVC設(shè)計模式的JAVA WEB應(yīng)用中,Hibernate可以作為模型層/數(shù)據(jù)訪問層。它通過配置文件(hibernate.properties或hibernate.cfg.xml)和映射文件(***.hbm.xml)把JAVA對象或PO(Persistent Object,持久化對象)映射到數(shù)據(jù)庫中的數(shù)據(jù)庫,然后通過操作PO,對數(shù)據(jù)表中的數(shù)據(jù)進行增,刪,改,查等操作。
除配置文件,映射文件和持久化類外,Hibernate的核心組件包括以下幾部分:
a)Configuration類:用來讀取Hibernate配置文件,并生成SessionFactory對象。
b)SessionFactory接口:產(chǎn)生Session實例工廠。
c)Session接口:用來操作PO。它有g(shù)et(),load(),save(),update()和delete()等方法用來對PO進行加載,保存,更新及刪除等操作。它是Hibernate的核心接口。
d)Query接口:用來對PO進行查詢操。它可以從Session的createQuery()方法生成。
e)Transaction接口:用來管理Hibernate事務(wù),它主要方法有commit()和rollback(),可以從Session的beginTrancation()方法生成。
Persistent Object
持久化對象可以是普通的Javabeans,惟一特殊的是它們與(僅一個)Session相關(guān)聯(lián)。JavaBeans在Hibernate中存在三種狀態(tài):
1.臨時狀態(tài)(transient):當(dāng)一個JavaBean對象在內(nèi)存中孤立存在,不與數(shù)據(jù)庫中的數(shù)據(jù)有任何關(guān)聯(lián)關(guān)系時,那么這個JavaBeans對象就稱為臨時對象(Transient Object)。
2.持久化狀態(tài)(persistent):當(dāng)一個JavaBean對象與一個Session相關(guān)聯(lián)時,就變成持久化對象(Persistent Object)
3.脫管狀態(tài)(detached):在這個Session被關(guān)閉的同時,這個對象也會脫離持久化狀態(tài),就變成脫管狀態(tài)(Detached Object),可以被應(yīng)用程序的任何層自由使用,例如可以做與表示層打交道的數(shù)據(jù)輿對象(Data Transfer Object)。
Hibernate的運行過程
Hibernate的運行過程如下:
A:應(yīng)用程序先調(diào)用Configration類,該類讀取Hibernate的配置文件及映射文件中的信息,并用這些信息生成一個SessionFactpry對象。
B:然后從SessionFactory對象生成一個Session對象,并用Session對象生成Transaction對象;可通過Session對象的get(),load(),save(),update(),delete()和saveOrUpdate()等方法對PO進行加載,保存,更新,刪除等操作;在查詢的情況下,可通過Session對象生成一個Query對象,然后利用Query對象執(zhí)行查詢操作;如果沒有異常,Transaction對象將 提交這些操作結(jié)果到數(shù)據(jù)庫中。
Hibernate的運行過程如下圖:
Hibernate簡單示例:
數(shù)據(jù):
create table T_register
(
id
int primary key,
userName
varchar(
30),
userPwd
varchar(
30),
sex
varchar(
10),
age
int)
視圖層:注冊頁面register.jsp
<%@ page language="java" contentType="text/html; charset=GBK"
pageEncoding="GBK"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=GBK"><title>Insert title here
</title></head><body><form action="servlet/RegisterServlet" method="POST"> 用戶名:
<input type="text" name="userName" /><BR> 密 碼:
<input type="text" name="userPwd" /><BR> 性 別:
<input type="text" name="sex" /><BR> 年 齡:
<input type="text" name="age" /><BR> <input type="submit" value="save" /></form></body></html> 設(shè)計持久化類TRegister.javapackage hibernate.PO;
/**
* 持久化類
*/public class TRegister
implements java.io.Serializable {
// Fields
private Integer id;
private String userName;
private String userPwd;
private String sex;
private Integer age;
// Constructors
/** default constructor */ public TRegister() {
}
/** 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;
}
// Property accessors
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return this.userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getUserPwd() {
return this.userPwd;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
public String getSex() {
return this.sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Integer getAge() {
return this.age;
}
public void setAge(Integer age) {
this.age = age;
}
}
設(shè)計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="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" /></session-factory></hibernate-configuration> 設(shè)計映射文件TRegister.hbm.xml<?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中并沒有設(shè)置該字段遞增,但在Hibernate中依然可以設(shè)置為遞增 --> <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> 設(shè)計hibernate基礎(chǔ)類HibernateUtil.javapackage hibernate;
/**
* hibernate 基礎(chǔ)類
* @author fengyan
* date 2007-01-09 02:32
*/import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class HibernateUtil {
private static final SessionFactory sessionFactory;
static {
try {
Configuration config =
new Configuration().configure("/hibernate/hibernate.cfg.xml");
sessionFactory = config.buildSessionFactory();
}
catch(Throwable e)
{
throw new ExceptionInInitializerError(e);
}
}
public static final ThreadLocal session =
new ThreadLocal();
public static Session currentSession()
throws HibernateException
{
Session s = (Session)session.get();
//Open a new Session,if this Thread has none yet
if(s ==
null || !s.isOpen())
{
s = sessionFactory.openSession();
session.set(s);
}
return s;
}
public static void closeSession()
throws HibernateException
{
Session s = (Session)session.get();
session.set(
null);
if(s !=
null)
s.close();
}
}
設(shè)計控制類package hibernate.servlet;
/**
* @author fengyan
* date 2007-01-09 02:44
* 設(shè)計Hibernate控制類
*/import hibernate.HibernateUtil;
import hibernate.PO.TRegister;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
public class RegisterServlet
extends HttpServlet {
private static final String CONTENT_TYPE = "text/html;charset=GBK";
public void init()
throws ServletException {
// Put your code here
}
public void destroy() {
super.destroy();
// Just puts "destroy" string in log
// Put your code here
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType(CONTENT_TYPE);
request.setCharacterEncoding("GBK");
PrintWriter out = response.getWriter();
String userName = request.getParameter("userName");
String userPwd = request.getParameter("userPwd");
String sex = request.getParameter("sex");
int age = Integer.parseInt(request.getParameter("age"));
TRegister rg =
new TRegister();
rg.setAge(age);
rg.setSex(sex);
rg.setUserName(userName);
rg.setUserPwd(userPwd);
Session session = HibernateUtil.currentSession();
//生成Session實例
Transaction tx = session.beginTransaction();
try {
session.save(rg);
//保存持久類對象
tx.commit();
//提交到數(shù)據(jù)庫
session.close();
response.sendRedirect("registerOK.jsp");
}
catch(HibernateException e)
{
e.printStackTrace();
tx.rollback();
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request,response);
}
}
編譯----->打包----->運行----->OK!