<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 89,  comments - 98,  trackbacks - 0

      對(duì)象、關(guān)系的映射(ORM)是一種耗時(shí)的工作,在Java環(huán)境下,有幾種框架來(lái)表示持久數(shù)據(jù),如實(shí)體Bean、OJB、JDO、Hibernate等。Hibernate是一種新的ORM映射工具,它不僅提供了從Java類到數(shù)據(jù)表的映射,也提供了數(shù)據(jù)查詢和恢復(fù)等機(jī)制。本文介紹怎么在Web應(yīng)用開(kāi)發(fā)中配置Hibernate的環(huán)境,并且使用Hibernate來(lái)開(kāi)發(fā)一個(gè)具體的實(shí)例。

      介紹

      面向?qū)ο蟮拈_(kāi)發(fā)方法是當(dāng)今的主流,但是同時(shí)我們不得不使用關(guān)系型數(shù)據(jù)庫(kù),所以在企業(yè)級(jí)應(yīng)用開(kāi)發(fā)的環(huán)境中,對(duì)象、關(guān)系的映射(ORM)是一種耗時(shí)的工作。圍繞對(duì)象關(guān)系的映射和持久數(shù)據(jù)的訪問(wèn),在Java領(lǐng)域中發(fā)展起來(lái)了一些API和框架,下面分別簡(jiǎn)單介紹。

      JDBC可以說(shuō)是訪問(wèn)持久數(shù)據(jù)層最原始、最直接的方法。在企業(yè)級(jí)應(yīng)用開(kāi)發(fā)中,我們可能使用DAO(Data Access Object)模式來(lái)把數(shù)據(jù)訪問(wèn)封裝起來(lái),然后在其它的層中同一調(diào)用。這種方式的優(yōu)點(diǎn)是運(yùn)行效率最高,缺點(diǎn)是把DAO對(duì)象和SQL語(yǔ)言緊密耦合在一起使得在大項(xiàng)目中難以維護(hù)。但是不管怎么說(shuō),使用JDBC來(lái)直接訪問(wèn)持久數(shù)據(jù)層是當(dāng)今企業(yè)級(jí)應(yīng)用開(kāi)發(fā)中使用最廣泛的。

      實(shí)體Bean是J2EE平臺(tái)中用來(lái)表示和訪問(wèn)持久數(shù)據(jù)的方式。雖然實(shí)體Bean是一種方便快捷的方法,但是在運(yùn)行時(shí)我們需要額外購(gòu)買EJB容器(當(dāng)然,如今也有免費(fèi)的EJB容器,如JBOSS),并且使用不同的應(yīng)用服務(wù)器,需要重新書(shū)寫不同的部署描述,使得在不同應(yīng)用服務(wù)器下移植企業(yè)級(jí)應(yīng)用會(huì)帶來(lái)一些困難。

      另外,在Java領(lǐng)域中,還有一些表示持久數(shù)據(jù)的框架,比如JDO和OJB,在這里就不詳細(xì)介紹了。

      Hibernate是一種新的ORM映射工具,它不僅提供了從Java類到數(shù)據(jù)表之間的映射,也提供了數(shù)據(jù)查詢和恢復(fù)機(jī)制。相對(duì)于使用JDBC和SQL來(lái)手工操作數(shù)據(jù)庫(kù),使用Hibernate,可以大大減少操作數(shù)據(jù)庫(kù)的工作量。

      Hibernate可以和多種Web服務(wù)器或者應(yīng)用服務(wù)器良好集成,如今已經(jīng)支持幾乎所有的流行的數(shù)據(jù)庫(kù)服務(wù)器(達(dá)16種)。

      下面我們來(lái)介紹怎么結(jié)合Hibernate2.0和Apache Tomcat5.0在Web應(yīng)用中使用Hibernate。

      配置

      1、下載安裝Tomcat,并且下載Hibernate的運(yùn)行環(huán)境(主要包含一些JAR包)。
      2、把要使用的數(shù)據(jù)庫(kù)的JDBC驅(qū)動(dòng)程序拷貝到%TOMCAT_HOME%\common\lib目錄下。筆者使用的是MYSQL,對(duì)應(yīng)的驅(qū)動(dòng)程序的JAR包為mm.mysql-2.0.4-bin.jar。
      3、在Tomcat的Webapps目錄下新建一個(gè)Web應(yīng)用,名字為hibernate。
      4、把Hibernate提供的hibernate2.jar和一些第三方的運(yùn)行庫(kù)拷貝到hibernate\WEB\INF\lib目錄下。(這些第三方的運(yùn)行庫(kù)包含在下載的Hibernate lib目錄下)
      5、在%TOMCAT_HOME%\conf\server.xml中Web應(yīng)用和數(shù)據(jù)源。在server.xml中加入以下的配置描述。

      例程1 配置web應(yīng)用

     <Context path="/hibernate" docBase="hibernate" debug="0"?? reloadable="true" crossContext="true">
      <Resource name="jdbc/hibernate" auth="Container" type="javax.sql.DataSource"/>??
    ???? <ResourceParams name="jdbc/hibernate">?
    ???? ?<parameter>??
    ???? ???? <name>factory</name>??
    ???? ??<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>??
    ???? ?</parameter>
    ???? ?<parameter>??
    ??? ???? <name>driverClassName</name>??
    ???? ?????? <value>org.gjt.mm.mysql.Driver</value>??
    ???? ? </parameter>?
    ???? ?? <parameter>?
    ???? ??? ???? <name>url</name>??
    ???? ??? ???? <value>jdbc:mysql:///test</value>??
    ???????? </parameter>??
    ???? ? <parameter>?
    ???? ? ???? <name>username</name>?
    ???? ???? ?<value>root</value>?
    ???? ? </parameter>??
    ???? ?<parameter>?
    ???????? <name>password</name>??
    ???????? <value></value>?
    ????????? </parameter>??
    ???? ?<parameter>?
    ????? <name>maxActive</name>?
    ????? <value>20</value>?
    ??? </parameter>
    ???????? <parameter>??
    ???? ?? <name>maxIdle</name>??
    ?????????? <value>10</value>
    ??? </parameter>?
    ??? <parameter>?
    ???? ???? <name>maxWait</name>?
    ????? <value>-1</value>?
    ??? </parameter>??
      </ResourceParams>??
     </Context>

      在這里,配置了一個(gè)名為hibernate的Web應(yīng)用,并且配置了一個(gè)數(shù)據(jù)源,數(shù)據(jù)源的JNDI名稱為jdbc/hibernate。您需要根據(jù)情況修改數(shù)據(jù)源的鏈接屬性。

      6、下一步就是書(shū)寫Hibernate的配置描述符??梢允褂肵ML的配置描述,也可以使用基于屬性的配置描述。在這里使用基于XML的配置描述。在hibernate\WEB-INF\classes目錄下新建一個(gè)hibernate.cfg.xml文件。然后加入例程2所示的內(nèi)容。

    <!DOCTYPE hibernate-configuration
    ??? PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
    ??? "http://hibernate.sourceforge.net/hibernate-configuration-2.0.dtd">

    <hibernate-configuration>
    ??? <session-factory>
    ??????? <property name="connection.datasource">java:comp/env/jdbc/hibernate</property>
    ??????? <property name="show_sql">false</property>
    ??????? <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property>
    ??????? <!-- Mapping files -->
    ??? </session-factory>
    </hibernate-configuration>

      注意connection.datasource屬性必須和server.xml中配置的數(shù)據(jù)源的屬性一樣。如果不是使用MYSQL,那么需要更改dialect屬性。

      到現(xiàn)在,配置基本完成,下面我們來(lái)開(kāi)發(fā)一個(gè)最簡(jiǎn)單的應(yīng)用。

      開(kāi)發(fā)持久對(duì)象、編寫映射描述

      我們使用hibernate來(lái)封裝一個(gè)簡(jiǎn)單的數(shù)據(jù)表。這個(gè)表的名字為Courses,它有兩個(gè)字段,一個(gè)是ID,它是Courses表的主鍵;另一個(gè)是name,表示Courses的名字。在數(shù)據(jù)庫(kù)中使用以下的腳本來(lái)創(chuàng)建這個(gè)表:

      create table Courses(CourseId varchar(32) not null, name varchar(32), constraint pk_Courses primary key (CourseId) );

      接下來(lái)的任務(wù)就是為Courses表書(shū)寫持久對(duì)象,如例程3所示。

      例程3 Courses的持久對(duì)象(Courses.java)

    package com.hellking.study.hibernate;

    import java.util.Set;

    /**
    ?*在hibernate中代表了Course表的類。
    ?*/
    public class Course
    {
    ?? /**每個(gè)屬性和表的一個(gè)字段對(duì)應(yīng)**/
    ?? private String id;
    ?? private String name;
    ??
    ?? /**students表示course中的學(xué)生,在后面才會(huì)用到,暫時(shí)不管**/
    ?? private Set students;
    ?? ?
    ??? /**屬性的訪問(wèn)方法**/
    ?public void setId(String string) {
    ??id = string;
    ?}
    ?
    ?public String getId() {
    ??return id;
    ?}
    ?
    ?public void setName(String name)
    ?{
    ??this.name=name;
    ?}
    ?public String getName()
    ?{
    ??return this.name;
    ?}
    ?public void setStudents(Set stud)
    ?{
    ??this.students=stud;
    ?}
    ?public Set getStudents()
    ?{
    ??return this.students;
    ?}
    }

      可以看出,在Course類中也包含了兩個(gè)屬性,id和name,它的屬性和表Courses的字段是一一對(duì)應(yīng)的,并且類型一致。

      書(shū)寫好了持久對(duì)象,接下來(lái)的任務(wù)就是書(shū)寫對(duì)象、關(guān)系映射描述。在hibernate\WEB-INF\classes目錄下新建一個(gè)Course.hbm.xml描述文件,內(nèi)容如例程4所示。

      例程4 Course.hbm.xml

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC
    ??? "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    ??? "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">

    <hibernate-mapping>
    ??? <class
    ??????? name="com.hellking.study.hibernate.Course"
    ??????? table="Courses"
    ??????? dynamic-update="false"
    ??? >

    ??????? <id
    ??????????? name="id"
    ??????????? column="CourseId"
    ??????????? type="string"
    ??????????? unsaved-value="any"
    ??????? >
    ??????????? <generator class="assigned"/>
    ??????? </id>

    ??????? <property
    ??????????? name="name"
    ??????????? type="string"
    ??????????? update="true"
    ??????????? insert="true"
    ??????????? column="Name"
    ??????? />?????
    ??? </class>
    </hibernate-mapping>

      在Course.hbm.xml映射文件中,指定了要映射的類和映射的表,并且指定了表的各個(gè)字段和Java對(duì)象中各個(gè)字段的映射關(guān)系,比如Course對(duì)象中的id屬性對(duì)應(yīng)了Courses表的courseId字段。

      接下來(lái)的任務(wù)就是在hibernate.cfg.xml中指定這個(gè)映射關(guān)系。如下所示:

    <session-factory>

    <!-- Mapping files -->?
    ?<mapping resource="Course.hbm.xml"/>
    </session-factory>

      編寫業(yè)務(wù)邏輯

      到此,我們已經(jīng)封裝了一個(gè)名為Courses的表,并且配置完成。接下來(lái)的任務(wù)就是在Web應(yīng)用開(kāi)發(fā)中使用它們,為了演示在Hibernate中對(duì)數(shù)據(jù)庫(kù)的不同類型的操作,我們開(kāi)發(fā)的Web應(yīng)用有以下的功能:
      增加一個(gè)Course;
      刪除一個(gè)Course;
      按照Course的名字進(jìn)行模糊搜索;
      查看系統(tǒng)中所有的Course。

      雖然我們可以直接在JSP中使用hibernate,但是往往我們不這樣,而是把這些業(yè)務(wù)邏輯封裝在JavaBean中,然后在JSP中通過(guò)調(diào)用JavaBean以訪問(wèn)Hibernate封裝的對(duì)象。

      由于訪問(wèn)通過(guò)使用hibernate有一些共性的操作,在這里我們把這些共性的操作封裝在一個(gè)專門的類中,這樣其它的類可以繼承它,如例程5所示。

      例程5 HibernateBase.java

    package com.hellking.study.hibernate;

    import net.sf.hibernate.*;
    import net.sf.hibernate.cfg.*;
    import java.util.*;
    import java.io.IOException;
    import java.io.PrintWriter;

    public abstract class HibernateBase
    {
    ?protected SessionFactory sessionFactory;//會(huì)話工廠,用于創(chuàng)建會(huì)話
    ??? protected Session session;//hibernate會(huì)話
    ??? protected Transaction transaction; //hiberante事務(wù)
    ???
    ??? public HibernateBase()throws HibernateException
    ??? {
    ??? ?this.initHibernate();
    ??? }
    ??? // 幫助方法
    ??? protected void initHibernate()
    ??????? throws HibernateException {

    ??????? // 裝載配置,構(gòu)造SessionFactory對(duì)象
    ??????? sessionFactory = new Configuration().configure().buildSessionFactory();
    ??? }
    ???
    ??? /**
    ???? *開(kāi)始一個(gè)hibernate事務(wù)
    ???? */
    ??? protected void beginTransaction()
    ??????? throws HibernateException {

    ??????? session = sessionFactory.openSession();
    ??????? transaction = session.beginTransaction();
    ??? }
    ???
    ??? /**
    ???? *結(jié)束一個(gè)hibernate事務(wù)。
    ???? */
    ??? protected void endTransaction(boolean commit)
    ??????? throws HibernateException {

    ??????? if (commit) {
    ??????????? transaction.commit();
    ??????? } else {
    ?????????? //如果是只讀的操作,不需要commit這個(gè)事務(wù)。
    ??????????? transaction.rollback();
    ??????? }
    ???????? session.close();
    ??? }
    }

      下面編寫業(yè)務(wù)邏輯類,新建一個(gè)名為CourseBean的JavaBean,并且CourseBean繼承HibernateBase類,代碼如例程6所示。

      例程6 CourseBean.java

    package com.hellking.study.hibernate;

    import net.sf.hibernate.*;
    import net.sf.hibernate.cfg.*;
    import java.util.*;

    /**
    ?*和course相關(guān)的業(yè)務(wù)邏輯
    ?*/
    public class CourseBean extends HibernateBase
    {
    ?public CourseBean()throws HibernateException
    ?{
    ??super();
    ?}
    ?/**
    ? *增加一個(gè)Course
    ? */
    ?public void addCourse(Course st)throws HibernateException
    ?{
    ??beginTransaction();
    ???????? session.save(st);????????
    ???????? endTransaction(true);
    ??? }
    ???
    ??? /**
    ???? *查詢系統(tǒng)中所有的Course,返回的是包含有Course持久對(duì)象的Iterator。
    ???? */
    ??? public Iterator getAllCourses()throws HibernateException
    ??? {
    ???? ?String queryString = "select courses from Course as courses";
    ??????? beginTransaction();
    ??????? Query query = session.createQuery(queryString);
    ??????? Iterator it= query.iterate();
    ??????? return it;
    ??? }
    ???
    ??? /**
    ???? *刪除給定ID的course
    ???? */
    ??? public void deleteCourse(String id)throws HibernateException
    ??? {
    ???? ?beginTransaction();??? ?
    ???? ?Course course=(Course)session.load(Course.class,id);??? ?
    ???? ?session.delete(course);
    ???? ?endTransaction(true);
    ???? }
    ???
    ??? /**
    ???? *按course的名字進(jìn)行模糊查找,返回的是包含有Course持久對(duì)象的Iterator。
    ???? */
    ??? public Iterator getSomeCourse(String name)throws HibernateException
    ??? {
    ????? ?String queryString = "select c from Course as c where c.name like :name" ;
    ???????? beginTransaction();
    ???????? Query query = session.createQuery(queryString);
    ???????? query.setString("name", "%"+name+"%");
    ??????? Iterator it= query.iterate();
    ??????? return it;
    ??? }??? ?
    }

      在CourseBean封裝了4個(gè)業(yè)務(wù)方法,你可以根據(jù)情況增加其它的業(yè)務(wù)方法。在CourseBean中,通過(guò)Hibernate來(lái)操作潛在的數(shù)據(jù)庫(kù)資源。

      要保存Course數(shù)據(jù)到數(shù)據(jù)庫(kù),可以通過(guò):

      session.save(Course);

      方法來(lái)保存,它相當(dāng)于使用在JDBC中執(zhí)行以下語(yǔ)句:

      Connection con=…
      Statement stmt=con.createStatement();
      stmt.executeUpdate("insert into courses values('"+course.getId(),+"','"+course.getName()+"')");
      con.close();

      可以看出,通過(guò)使用Hibernate,可以大大減少數(shù)據(jù)訪問(wèn)的復(fù)雜度。

      在JSP中調(diào)用業(yè)務(wù)邏輯

      添加數(shù)據(jù)

      CourseBean這個(gè)業(yè)務(wù)對(duì)象封裝了和Hibernate的交互關(guān)系,從而使JSP和Hibernate關(guān)系的解藕。我們來(lái)看測(cè)試主頁(yè)面的部分代碼,如例程7所示。

      例程7 測(cè)試Hibernate開(kāi)發(fā)的應(yīng)用(course.jsp)

    <%@ page import="java.sql.*,java.util.*" errorPage="error.jsp"%>
    <jsp:useBean id="course" class="com.hellking.study.hibernate.Course" scope="page">
    <jsp:setProperty name="course" property="*"/>
    </jsp:useBean>
    <jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>
    <html><body><center>
    <%?
    ? try
    ? {
    ? if(course.getId().equals(null)||course.getId().equals(""));
    ? else courseBusiness.addCourse(course);
    ?
    ? %>
    成功添加了Course:<br>
    name:<%=course.getName()%>
    Id:<%=course.getId()%>
    <%
    }
    ? catch(Exception e)
    ? {
    ? }?
    %>

    <hr>
    <br>::增加一個(gè)course::<br>
    <form action="course.jsp" method="get" name="add">
    id:<input type=text name="id"><br>
    name:<input type=text name="name"><br>
    <input type=submit value="submit"><br>
    </form>
    <hr>
    ::按名字模糊查找::<br>
    <form action="queryCourse.jsp" method="get" name="queryByName">
    name:<input type=text name="name"><br>
    <input type=submit value="query"><br>
    </form>
    <hr>
    ::刪除一個(gè)Course::<br>
    <form action="deleteCourse.jsp" method="get" name="queryByName">
    id:<input type=text name="id"><br>
    <input type=submit value="delete"><br>
    </form>
    <hr>
    <a href=viewAll.jsp>::查看所有Course::<a>
    </body>
    </html>

      首先通過(guò)一個(gè)值對(duì)象Course(這個(gè)類正好是Hibernate使用的持久對(duì)象,這里作為值對(duì)象來(lái)傳遞數(shù)據(jù))接收獲得的參數(shù),然后CourseBean的addCourse(Course)方法把數(shù)據(jù)保存到數(shù)據(jù)庫(kù)??梢钥闯?,通過(guò)使用Hibernate,把數(shù)據(jù)從表單中添加到數(shù)據(jù)庫(kù)非常簡(jiǎn)單。

      查詢

      下面來(lái)看模糊查找的JSP代碼,如例程8所示。

      例程8 按名字模糊查找Course

    <%@ page import="java.sql.*,java.util.*,com.hellking.study.hibernate.Course" errorPage="error.jsp"%>
    <jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

    <% try
    {
    ?? Iterator it=courseBusiness.getSomeCourse((String)request.getParameter("name"));
    ?? while(it.hasNext())
    ?? {
    ???? Course temp=(Course)it.next();
    ???? out.println("<tr><td>"+temp.getId()+"</td>");
    ???? out.println("<td>"+temp.getName()+"</td></tr>");
    ?? }
    ? }
    ? catch(Exception e)
    ? {
    ??? out.println(e.getMessage());
    ?? }
    %>
    ….

      它實(shí)際上調(diào)用的是CourseBean的Iterator getSomeCourse(String name)方法。我們來(lái)回顧一下這個(gè)方法中的代碼:

      /**
    ???? *按course的名字進(jìn)行模糊查找
    ???? */
    ??? public Iterator getSomeCourse(String name)throws HibernateException
    ??? {
    ????? ?String queryString = "select c from Course as c where c.name like :name" ;
    ??????? beginTransaction();
    ??????? Query query = session.createQuery(queryString);
    ???????? query.setString("name", "%"+name+"%");
    ??????? Iterator it= query.iterate();
    ??????? return it;
    ??? }

      在查詢前,首先調(diào)用beginTransaction方法啟動(dòng)新的Hibernate事務(wù),然后創(chuàng)建一個(gè)Query對(duì)象,在創(chuàng)建這個(gè)對(duì)象時(shí),同時(shí)指定查詢的語(yǔ)句。

      注意,在查詢語(yǔ)句:

      select c from Course as c where c.name like :name"

      中,它雖然和普通的SQL語(yǔ)句相似,但是不同,在數(shù)據(jù)庫(kù)中,使用的表的名字是Courses,而在這個(gè)查詢語(yǔ)句中使用的是Course,它和持久對(duì)象的名字一致,也就是說(shuō),這個(gè)查詢的概念是查詢持久對(duì)象,而不是數(shù)據(jù)庫(kù)的記錄。

      創(chuàng)建了查詢對(duì)象Query后,需要設(shè)置查詢的參數(shù),它和在JDBC中PreparedStatement對(duì)象中設(shè)置參數(shù)的方法相似。通過(guò)"Iterator it= query.iterate()"語(yǔ)句來(lái)執(zhí)行查詢,并且返回一個(gè)Iterator對(duì)象。在這里使用了Hibernate提供的查詢機(jī)制,一般的JDBC查詢返回的是ResultSet對(duì)象,而這里返回的是包含了CourseBean對(duì)象的Iterator。

      要查詢系統(tǒng)中所有的Course,也同樣非常簡(jiǎn)單,可以通過(guò)例程9所示的代碼實(shí)現(xiàn)。

      例程9 查詢數(shù)據(jù)庫(kù)中所有的Course


    <jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

    <% try
    {
    ?? Iterator it=courseBusiness.getAllCourses();
    ?? while(it.hasNext())
    ?? {
    ???? Course temp=(Course)it.next();
    ???? out.println("<tr><td>"+temp.getId()+"</td>");
    ???? out.println("<td>"+temp.getName()+"</td></tr>");
    ?? }
    ? }
    ? catch(Exception e)
    ? {
    ??? out.println(e.getMessage());
    ?? }
    %>

      實(shí)際上調(diào)用的是CourseBean的getAllCourses方法,它和getSomeCourse方法機(jī)制一樣,就不再介紹了。

      刪除數(shù)據(jù)

      在JSP中,使用以下的代碼來(lái)執(zhí)行刪除操作。

      例程10 刪除數(shù)據(jù)庫(kù)中Courses表的記錄

    <jsp:useBean id="courseBusiness" class="com.hellking.study.hibernate.CourseBean" scope="page"/>

    刪除id為:<%=request.getParameter("id")%>的course::::<br>

    <% try
    {
    ?courseBusiness.deleteCourse(request.getParameter("id"));
    ?out.println("刪除成功");
    }
    ? catch(Exception e)
    ? {
    ??? out.println("不存在這個(gè)記錄");
    ?? }
    %>

      我們來(lái)看CourseBean中執(zhí)行刪除操作的具體代碼:

      /**
    ???? *刪除給定ID的course
    ???? */
    ??? public void deleteCourse(String id)throws HibernateException
    ??? {
    ??? ?beginTransaction();??? ?
    ??? ?Course course=(Course)session.load(Course.class,id);??? ?
    ??? ?session.delete(course);
    ??? ?endTransaction(true);
    ???? }

      在這個(gè)方法中,首先開(kāi)始一個(gè)事務(wù),然后通過(guò)session.load(Course.class,id)方法來(lái)裝載指定ID的持久對(duì)象,接下來(lái)通過(guò)"session.delete(course)"來(lái)刪除已經(jīng)裝載的course,并且結(jié)束Hibernate事務(wù)。

      總結(jié)

      下面總結(jié)一下使用Hibernate的開(kāi)發(fā)過(guò)程:

      1、配置Hibernate(一次即可);
      2、確定數(shù)據(jù)表;
      3、創(chuàng)建持久對(duì)象;
      4、編寫對(duì)象和數(shù)據(jù)表的映射描述;
      5、編寫和業(yè)務(wù)邏輯。

      實(shí)際上,上面的過(guò)程和使用EJB沒(méi)有什么區(qū)別:在使用EJB時(shí),首先當(dāng)然也是配置環(huán)境,初始化數(shù)據(jù)表;然后創(chuàng)建實(shí)體Bean(對(duì)象于Hibernate的持久對(duì)象);接下來(lái)編寫部署描述符(ejb-jar.xml,廠商專有的部署描述),在這些部署描述符里,指定了EJB和數(shù)據(jù)表的映射關(guān)系,如果多個(gè)實(shí)體Bean存在關(guān)聯(lián)關(guān)系,需要描述它們之間的關(guān)系,這些描述對(duì)應(yīng)于Hibernate中持久對(duì)象的描述,如Course.hbm.xml;往往我們并不在應(yīng)用程序中直接操作實(shí)體Bean,而是通過(guò)業(yè)務(wù)對(duì)象(如會(huì)話Bean)來(lái)操作,這里的會(huì)話Bean可以簡(jiǎn)單的和Hibernate中執(zhí)行業(yè)務(wù)邏輯的JavaBean對(duì)應(yīng)。這里只是簡(jiǎn)單的類比,不是絕對(duì)的,比如我們同樣可以在會(huì)話Bean中訪問(wèn)Hibernate持久對(duì)象,也就是說(shuō)使用Hibernate,同樣可以把業(yè)務(wù)邏輯放在會(huì)話Bean中。

      通過(guò)本文的學(xué)習(xí),相信讀者對(duì)Hibernate已經(jīng)有了初步的認(rèn)識(shí),并且能夠使用Hibernate開(kāi)發(fā)簡(jiǎn)單的應(yīng)用。在下一篇中,我們將學(xué)習(xí)怎么使用Hibernate來(lái)為復(fù)雜的數(shù)據(jù)表進(jìn)行映射,并且維護(hù)它們之間的關(guān)系。

    posted on 2006-06-26 09:25 水煮三國(guó) 閱讀(156) 評(píng)論(0)  編輯  收藏

    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(4)

    隨筆分類(85)

    隨筆檔案(89)

    文章分類(14)

    文章檔案(42)

    收藏夾(37)

    java

    oracle

    Sybase

    搜索

    •  

    積分與排名

    • 積分 - 210957
    • 排名 - 266

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 四虎影视免费在线| 亚洲一区无码中文字幕乱码| 色视频色露露永久免费观看| 久9这里精品免费视频| 美女黄频视频大全免费的| 亚洲精品二三区伊人久久| 久久夜色精品国产亚洲AV动态图| 免费播放春色aⅴ视频| 18禁成年无码免费网站无遮挡| 国产精品99精品久久免费| 一级毛片一级毛片免费毛片| 日本亚洲高清乱码中文在线观看| 亚洲一区精品视频在线| 亚洲国产精品久久丫| 久久久无码精品亚洲日韩按摩 | 97久久国产亚洲精品超碰热| 亚洲国产综合专区在线电影| 亚洲综合网站色欲色欲| 日本高清免费不卡视频| 手机在线免费视频| 天天天欲色欲色WWW免费| 免费福利网站在线观看| 18禁黄网站禁片免费观看不卡| 国产一精品一AV一免费| 两个人的视频www免费| 国产在线观看无码免费视频| h视频免费高清在线观看| 国产精品免费观看视频| 国产高清视频免费在线观看| 人成免费在线视频| 国产精品美女免费视频观看| 两性色午夜免费视频| 日韩免费电影网站| 91精品啪在线观看国产线免费| 57pao一国产成视频永久免费| 88xx成人永久免费观看| 又大又硬又爽又粗又快的视频免费| 91热久久免费精品99| 免费h片在线观看网址最新| 中文字幕无码不卡免费视频| 亚洲免费综合色在线视频|