久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

Hibernate框架簡(jiǎn)述

 風(fēng)吹亂了流年 2016-10-15

Hibernate的核心組件
在基于MVC設(shè)計(jì)模式的JAVA WEB應(yīng)用中,,Hibernate可以作為模型層/數(shù)據(jù)訪問層。它通過配置文件(hibernate.properties或hibernate.cfg.xml)和映射文件(***.hbm.xml)把JAVA對(duì)象或PO(Persistent Object,持久化對(duì)象)映射到數(shù)據(jù)庫中的數(shù)據(jù)庫,,然后通過操作PO,,對(duì)數(shù)據(jù)表中的數(shù)據(jù)進(jìn)行增,,刪,改,,查等操作,。
除配置文件,映射文件和持久化類外,,Hibernate的核心組件包括以下幾部分:
a)Configuration類:用來讀取Hibernate配置文件,,并生成SessionFactory對(duì)象。
b)SessionFactory接口:產(chǎn)生Session實(shí)例工廠,。
c)Session接口:用來操作PO,。它有g(shù)et(),load(),save(),update()和delete()等方法用來對(duì)PO進(jìn)行加載,保存,,更新及刪除等操作,。它是Hibernate的核心接口。
d)Query接口:用來對(duì)PO進(jìn)行查詢操,。它可以從Session的createQuery()方法生成,。
e)Transaction接口:用來管理Hibernate事務(wù),它主要方法有commit()和rollback(),可以從Session的beginTrancation()方法生成,。

Persistent Object
持久化對(duì)象可以是普通的Javabeans,惟一特殊的是它們與(僅一個(gè))Session相關(guān)聯(lián),。JavaBeans在Hibernate中存在三種狀態(tài):
1.臨時(shí)狀態(tài)(transient):當(dāng)一個(gè)JavaBean對(duì)象在內(nèi)存中孤立存在,,不與數(shù)據(jù)庫中的數(shù)據(jù)有任何關(guān)聯(lián)關(guān)系時(shí),,那么這個(gè)JavaBeans對(duì)象就稱為臨時(shí)對(duì)象(Transient Object)。
2.持久化狀態(tài)(persistent):當(dāng)一個(gè)JavaBean對(duì)象與一個(gè)Session相關(guān)聯(lián)時(shí),,就變成持久化對(duì)象(Persistent Object)
3.脫管狀態(tài)(detached):在這個(gè)Session被關(guān)閉的同時(shí),,這個(gè)對(duì)象也會(huì)脫離持久化狀態(tài),就變成脫管狀態(tài)(Detached Object),,可以被應(yīng)用程序的任何層自由使用,,例如可以做與表示層打交道的數(shù)據(jù)輿對(duì)象(Data Transfer Object)。

Hibernate的運(yùn)行過程
Hibernate的運(yùn)行過程如下:
A:應(yīng)用程序先調(diào)用Configration類,,該類讀取Hibernate的配置文件及映射文件中的信息,,并用這些信息生成一個(gè)SessionFactpry對(duì)象。
B:然后從SessionFactory對(duì)象生成一個(gè)Session對(duì)象,,并用Session對(duì)象生成Transaction對(duì)象;可通過Session對(duì)象的get(),load(),save(),update(),delete()和saveOrUpdate()等方法對(duì)PO進(jìn)行加載,,保存,更新,,刪除等操作;在查詢的情況下,,可通過Session對(duì)象生成一個(gè)Query對(duì)象,然后利用Query對(duì)象執(zhí)行查詢操作;如果沒有異常,,Transaction對(duì)象將 提交這些操作結(jié)果到數(shù)據(jù)庫中,。

Hibernate的運(yùn)行過程如下圖:

Hibernate簡(jiǎn)單示例:
數(shù)據(jù):

create table T_register
(
    id    int primary key,
    userName varchar(30),
    userPwd varchar(30),
    sex varchar(10),
    age int
)


視圖層:注冊(cè)頁面register.jsp

<%@ page language="java" contentType="text/html; charset=GBK"
    pageEncoding
="GBK"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www./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è)計(jì)持久化類TRegister.java

package 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è)計(jì)Hibernate配置文件hibernate.cfg.xml

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate./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è)計(jì)映射文件TRegister.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate./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è)計(jì)hibernate基礎(chǔ)類HibernateUtil.java
package 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è)計(jì)控制類
package hibernate.servlet;
/**
 * 
@author fengyan
 * date  2007-01-09 02:44
 * 設(shè)計(jì)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實(shí)例
        Transaction tx = session.beginTransaction();
        
        try
        {
            session.save(rg);    //保存持久類對(duì)象
            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);
        
    }



}

編譯----->打包----->運(yùn)行----->OK!

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào),。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多