使用Hibernate的一个完整例子.docx
- 文档编号:6172197
- 上传时间:2023-01-04
- 格式:DOCX
- 页数:8
- 大小:21.83KB
使用Hibernate的一个完整例子.docx
《使用Hibernate的一个完整例子.docx》由会员分享,可在线阅读,更多相关《使用Hibernate的一个完整例子.docx(8页珍藏版)》请在冰豆网上搜索。
使用Hibernate的一个完整例子
使用Hibernate的一个完整例子
陈亚强(cyqcims@)
北京华园天一科技有限公司高级软件工程师
2003年10月
对象、关系的映射(ORM)是一种耗时的工作,在Java环境下,有几种框架来表示持久数据,如实体Bean、OJB、JDO、Hibernate等。
Hibernate是一种新的ORM映射工具,它不仅提供了从Java类到数据表的映射,也提供了数据查询和恢复等机制。
本文介绍怎么在Web应用开发中配置Hibernate的环境,并且使用Hibernate来开发一个具体的实例。
阅读本文前您需要以下的知识和工具:
Tomcat5.09,可以从下载;
Hibernate2.0相关运行环境,可以从http:
//www.hibernate.org/下载;
至少一个数据库服务器并且有相关的JDBC驱动程序。
本文的参考资料见参考资料。
介绍
面向对象的开发方法是当今的主流,但是同时我们不得不使用关系型数据库,所以在企业级应用开发的环境中,对象、关系的映射(ORM)是一种耗时的工作。
围绕对象关系的映射和持久数据的访问,在Java领域中发展起来了一些API和框架,下面分别简单介绍。
JDBC可以说是访问持久数据层最原始、最直接的方法。
在企业级应用开发中,我们可能使用DAO(DataAccessObject)模式来把数据访问封装起来,然后在其它的层中同一调用。
这种方式的优点是运行效率最高,缺点是把DAO对象和SQL语言紧密耦合在一起使得在大项目中难以维护。
但是不管怎么说,使用JDBC来直接访问持久数据层是当今企业级应用开发中使用最广泛的。
实体Bean是J2EE平台中用来表示和访问持久数据的方式。
虽然实体Bean是一种方便快捷的方法,但是在运行时我们需要额外购买EJB容器(当然,如今也有免费的EJB容器,如JBOSS),并且使用不同的应用服务器,需要重新书写不同的部署描述,使得在不同应用服务器下移植企业级应用会带来一些困难。
另外,在Java领域中,还有一些表示持久数据的框架,比如JDO和OJB,在这里就不详细介绍了。
Hibernate是一种新的ORM映射工具,它不仅提供了从Java类到数据表之间的映射,也提供了数据查询和恢复机制。
相对于使用JDBC和SQL来手工操作数据库,使用Hibernate,可以大大减少操作数据库的工作量。
Hibernate可以和多种Web服务器或者应用服务器良好集成,如今已经支持几乎所有的流行的数据库服务器(达16种)。
下面我们来介绍怎么结合Hibernate2.0和ApacheTomcat5.0在Web应用中使用Hibernate。
配置
1、下载安装Tomcat,并且下载Hibernate的运行环境(主要包含一些JAR包)。
2、把要使用的数据库的JDBC驱动程序拷贝到%TOMCAT_HOME%\common\lib目录下。
笔者使用的是MYSQL,对应的驱动程序的JAR包为mm.mysql-2.0.4-bin.jar。
3、在Tomcat的Webapps目录下新建一个Web应用,名字为hibernate。
4、把Hibernate提供的hibernate2.jar和一些第三方的运行库拷贝到hibernate\WEB\INF\lib目录下。
(这些第三方的运行库包含在下载的Hibernatelib目录下)
5、在%TOMCAT_HOME%\conf\server.xml中Web应用和数据源。
在server.xml中加入以下的配置描述。
例程1配置web应用
mysql:
///test
在这里,配置了一个名为hibernate的Web应用,并且配置了一个数据源,数据源的JNDI名称为jdbc/hibernate。
您需要根据情况修改数据源的链接属性。
6、下一步就是书写Hibernate的配置描述符。
可以使用XML的配置描述,也可以使用基于属性的配置描述。
在这里使用基于XML的配置描述。
在hibernate\WEB-INF\classes目录下新建一个hibernate.cfg.xml文件。
然后加入例程2所示的内容。
DOCTYPEhibernate-configurationPUBLIC"-//Hibernate/HibernateConfigurationDTD//EN""
comp/env/jdbc/hibernate --Mappingfiles--> 注意connection.datasource属性必须和server.xml中配置的数据源的属性一样。 如果不是使用MYSQL,那么需要更改dialect属性。 到现在,配置基本完成,下面我们来开发一个最简单的应用。 开发持久对象、编写映射描述 我们使用hibernate来封装一个简单的数据表。 这个表的名字为Courses,它有两个字段,一个是ID,它是Courses表的主键;另一个是name,表示Courses的名字。 在数据库中使用以下的脚本来创建这个表: createtableCourses(CourseIdvarchar(32)notnull,namevarchar(32),constraintpk_Coursesprimarykey(CourseId)); 接下来的任务就是为Courses表书写持久对象,如例程3所示。 例程3Courses的持久对象(Courses.java) packagecom.hellking.study.hibernate;importjava.util.Set;/***在hibernate中代表了Course表的类。 */publicclassCourse{/**每个属性和表的一个字段对应**/privateStringid;privateStringname;/**students表示course中的学生,在后面才会用到,暂时不管**/privateSetstudents;/**属性的访问方法**/publicvoidsetId(Stringstring){id=string;}publicStringgetId(){returnid;}publicvoidsetName(Stringname){this.name=name;}publicStringgetName(){returnthis.name;}publicvoidsetStudents(Setstud){this.students=stud;}publicSetgetStudents(){returnthis.students;}} 可以看出,在Course类中也包含了两个属性,id和name,它的属性和表Courses的字段是一一对应的,并且类型一致。 书写好了持久对象,接下来的任务就是书写对象、关系映射描述。 在hibernate\WEB-INF\classes目录下新建一个Course.hbm.xml描述文件,内容如例程4所示。 例程4Course.hbm.xml xmlversion="1.0"? > DOCTYPEhibernate-mappingPUBLIC"-//Hibernate/HibernateMappingDTD2.0//EN"" 在Course.hbm.xml映射文件中,指定了要映射的类和映射的表,并且指定了表的各个字段和Java对象中各个字段的映射关系,比如Course对象中的id属性对应了Courses表的courseId字段。 接下来的任务就是在hibernate.cfg.xml中指定这个映射关系。 如下所示: --Mappingfiles--> 编写业务逻辑 到此,我们已经封装了一个名为Courses的表,并且配置完成。 接下来的任务就是在Web应用开发中使用它们,为了演示在Hibernate中对数据库的不同类型的操作,我们开发的Web应用有以下的功能: 增加一个Course; 删除一个Course; 按照Course的名字进行模糊搜索; 查看系统中所有的Course。 虽然我们可以直接在JSP中使用hibernate,但是往往我们不这样,而是把这些业务逻辑封装在JavaBean中,然后在JSP中通过调用JavaBean以访问Hibernate封装的对象。 由于访问通过使用hibernate有一些共性的操作,在这里我们把这些共性的操作封装在一个专门的类中,这样其它的类可以继承它,如例程5所示。 例程5HibernateBase.java packagecom.hellking.study.hibernate;importnet.sf.hibernate.*;importnet.sf.hibernate.cfg.*;importjava.util.*;importjava.io.IOException;importjava.io.PrintWriter;publicabstractclassHibernateBase{protectedSessionFactorysessionFactory;//会话工厂,用于创建会话protectedSessionsession;//hibernate会话protectedTransactiontransaction;//hiberante事务publicHibernateBase()throwsHibernateException{this.initHibernate();}//帮助方法protectedvoidinitHibernate()throwsHibernateException{//装载配置,构造SessionFactory对象sessionFactory=newConfiguration().configure().buildSessionFactory();}/***开始一个hibernate事务*/protectedvoidbeginTransaction()throwsHibernateException{session=sessionFactory.openSession();transaction=session.beginTransaction();}/***结束一个hibernate事务。 */protectedvoidendTransaction(booleancommit)throwsHibernateException{if(commit){mit();}else{//如果是只读的操作,不需要commit这个事务。 transaction.rollback();}session.close();}} 下面编写业务逻辑类,新建一个名为CourseBean的JavaBean,并且CourseBean继承HibernateBase类,代码如例程6所示。 例程6CourseBean.java packagecom.hellking.study.hibernate;importnet.sf.hibernate.*;importnet.sf.hibernate.cfg.*;importjava.util.*;/***和course相关的业务逻辑*/publicclassCourseBeanextendsHibernateBase{publicCourseBean()throwsHibernateException{super();}/***增加一个Course*/publicvoidaddCourse(Coursest)throwsHibernateException{beginTransaction();session.save(st);endTransaction(true);}/***查询系统中所有的Course,返回的是包含有Course持久对象的Iterator。 */publicIteratorgetAllCourses()throwsHibernateException{StringqueryString="selectcoursesfromCourseascourses";beginTransaction();Queryquery=session.createQuery(queryString);Iteratorit=query.iterate();returnit;}/***删除给定ID的course*/publicvoiddeleteCourse(Stringid)throwsHibernateException{beginTransaction();Coursecourse=(Course)session.load(Course.class,id);session.delete(course);endTransaction(true);}/***按course的名字进行模糊查找,返回的是包含有Course持久对象的Iterator。 */publicIteratorgetSomeCourse(Stringname)throwsHibernateException{StringqueryString="selectcfromCourseascwherec.namelike: name";beginTransaction();Queryquery=session.createQuery(queryString);query.setString("name","%"+name+"%");Iteratorit=query.iterate();returnit;}} 在CourseBean封装了4个业务方法,你可以根据情况增加其它的业务方法。 在CourseBean中,通过Hibernate来操作潜在的数据库资源。 要保存Course数据到数据库,可以通过: session.save(Course); 方法来保存,它相当于使用在JDBC中执行以下语句: Connectioncon=…Statementstmt=con.createStatement();stmt.executeUpdate("insertintocoursesvalues('"+course.getId(),+"','"+course.getName()+"')");con.close(); 可以看出,通过使用Hibernate,可以大大减少数据访问的复杂度。 在JSP中调用业务逻辑 添加数据 CourseBean这个业务对象封装了和Hibernate的交互关系,从而使JSP和Hibernate关系的解藕。 我们来看测试主页面的部分代码,如例程7所示。 例程7测试Hibernate开发的应用(course.jsp) <%@pageimport="java.sql.*,java.util.*"errorPage="error.jsp"%> useBeanid="course"class="com.hellking.study.hibernate.Course"scope="page"> setPropertyname="course"property="*"/> useBean> useBeanid="courseBusiness"class="com.hellking.study.hibernate.CourseBean"scope="page"/> <%=course.getName()%>Id: <%=course.getId()%><%}catch(Exceptione){}%> : 增加一个course: : : 按名字模糊查找: : : 删除一个Course: : : 查看所有Course: : 首先通过一个值对象Course(这个类正好是Hibernate使用的持久对象,这里作为值对象来传递数据)接收获得的参数,然后CourseBean的addCourse(Course)方法把数据保存到数据库。 可以看出,通过使用Hibernate,把数据从表单中添加到数据库非常简单。 查询 下面来看模糊查找的JSP代码,如例程8所示。 例程8按名字模糊查找Course <%@pageimport="java.sql.*,java.util.*,com.hellking.study.hibernate.Course"errorPage="error.jsp"%> useBeanid="courseBusiness"class="com.hellking.study.hibernate.CourseBean"scope="page"/>…<%try{Iteratorit=courseBusiness.getSomeCourse((String)request.getParameter("name"));while(it.hasNext()){Coursetemp=(Course)it.next();out.println("
name:
:
name:
:
: ");}}catch(Exceptione){out.println(e.get"+temp.getId()+" ");out.println(""+temp.getName()+"
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 使用 Hibernate 一个 完整 例子