欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    使用Hibernate的一个完整例子.docx

    • 资源ID:6172197       资源大小:21.83KB        全文页数:8页
    • 资源格式: DOCX        下载积分:12金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要12金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    使用Hibernate的一个完整例子.docx

    1、使用Hibernate的一个完整例子使用Hibernate的一个完整例子陈亚强 (cyqcims)北京华园天一科技有限公司高级软件工程师2003 年 10 月对象、关系的映射(ORM)是一种耗时的工作,在Java环境下,有几种框架来表示持久数据,如实体Bean、OJB、JDO、Hibernate等。Hibernate是一种新的ORM映射工具,它不仅提供了从Java类到数据表的映射,也提供了数据查询和恢复等机制。本文介绍怎么在Web应用开发中配置Hibernate的环境,并且使用Hibernate来开发一个具体的实例。阅读本文前您需要以下的知识和工具:Tomcat 5.09,可以从 下载;Hib

    2、ernate2.0 相关运行环境,可以从 http:/www.hibernate.org/ 下载;至少一个数据库服务器并且有相关的JDBC驱动程序。本文的参考资料见 参考资料。介绍面向对象的开发方法是当今的主流,但是同时我们不得不使用关系型数据库,所以在企业级应用开发的环境中,对象、关系的映射(ORM)是一种耗时的工作。围绕对象关系的映射和持久数据的访问,在Java领域中发展起来了一些API和框架,下面分别简单介绍。JDBC可以说是访问持久数据层最原始、最直接的方法。在企业级应用开发中,我们可能使用DAO(Data Access Object)模式来把数据访问封装起来,然后在其它的层中同一调用

    3、。这种方式的优点是运行效率最高,缺点是把DAO对象和SQL语言紧密耦合在一起使得在大项目中难以维护。但是不管怎么说,使用JDBC来直接访问持久数据层是当今企业级应用开发中使用最广泛的。实体Bean是J2EE平台中用来表示和访问持久数据的方式。虽然实体Bean是一种方便快捷的方法,但是在运行时我们需要额外购买EJB容器(当然,如今也有免费的EJB容器,如JBOSS),并且使用不同的应用服务器,需要重新书写不同的部署描述,使得在不同应用服务器下移植企业级应用会带来一些困难。另外,在Java领域中,还有一些表示持久数据的框架,比如JDO和OJB,在这里就不详细介绍了。Hibernate是一种新的OR

    4、M映射工具,它不仅提供了从Java类到数据表之间的映射,也提供了数据查询和恢复机制。相对于使用JDBC和SQL来手工操作数据库,使用Hibernate,可以大大减少操作数据库的工作量。Hibernate可以和多种Web服务器或者应用服务器良好集成,如今已经支持几乎所有的流行的数据库服务器(达16种)。下面我们来介绍怎么结合Hibernate2.0和Apache Tomcat5.0在Web应用中使用Hibernate。配置1、 下载安装Tomcat,并且下载Hibernate的运行环境(主要包含一些JAR包)。2、 把要使用的数据库的JDBC驱动程序拷贝到%TOMCAT_HOME%commonl

    5、ib目录下。笔者使用的是MYSQL,对应的驱动程序的JAR包为mm.mysql-2.0.4-bin.jar。3、 在Tomcat的Webapps目录下新建一个Web应用,名字为hibernate。4、 把Hibernate提供的hibernate2.jar和一些第三方的运行库拷贝到hibernateWEBINFlib目录下。(这些第三方的运行库包含在下载的Hibernate lib目录下)5、 在%TOMCAT_HOME%confserver.xml中Web应用和数据源。在server.xml中加入以下的配置描述。例程1 配置web应用 factory mons.dbcp.BasicDataS

    6、ourceFactory driverClassName org.gjt.mm.mysql.Driver url jdbc:mysql:/test username root password maxActive 20 maxIdle 10 maxWait -1 在这里,配置了一个名为hibernate的Web应用,并且配置了一个数据源,数据源的JNDI名称为jdbc/hibernate。您需要根据情况修改数据源的链接属性。6、 下一步就是书写Hibernate的配置描述符。可以使用XML的配置描述,也可以使用基于属性的配置描述。在这里使用基于XML的配置描述。在hibernateWEB-IN

    7、Fclasses目录下新建一个hibernate.cfg.xml文件。然后加入例程2所示的内容。 !DOCTYPE hibernate-configuration PUBLIC -/Hibernate/Hibernate Configuration DTD/EN java:comp/env/jdbc/hibernate false net.sf.hibernate.dialect.MySQLDialect 注意connection.datasource属性必须和server.xml中配置的数据源的属性一样。如果不是使用MYSQL,那么需要更改dialect属性。到现在,配置基本完成,下面我们来

    8、开发一个最简单的应用。开发持久对象、编写映射描述我们使用hibernate来封装一个简单的数据表。这个表的名字为Courses,它有两个字段,一个是ID,它是Courses表的主键;另一个是name,表示Courses的名字。在数据库中使用以下的脚本来创建这个表:create table Courses(CourseId varchar(32) not null, name varchar(32), constraint pk_Courses primary key (CourseId) );接下来的任务就是为Courses表书写持久对象,如例程3所示。例程3 Courses的持久对象(Cou

    9、rses.java) package com.hellking.study.hibernate; import java.util.Set; /* *在hibernate中代表了Course表的类。 */ public class Course /*每个属性和表的一个字段对应*/ private String id; private String name; /*students表示course中的学生,在后面才会用到,暂时不管*/ private Set students; /*属性的访问方法*/ public void setId(String string) id = string; p

    10、ublic 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类中也包含了两个属性,id和name,它的属性和表Courses的字段是一一对应的,并且类型一致。书写好了持久对象,接下来的任务

    11、就是书写对象、关系映射描述。在hibernateWEB-INFclasses目录下新建一个Course.hbm.xml描述文件,内容如例程4所示。例程4 Course.hbm.xml !DOCTYPE hibernate-mapping PUBLIC -/Hibernate/Hibernate Mapping DTD 2.0/EN 在Course.hbm.xml映射文件中,指定了要映射的类和映射的表,并且指定了表的各个字段和Java对象中各个字段的映射关系,比如Course对象中的id属性对应了Courses表的courseId字段。接下来的任务就是在hibernate.cfg.xml中指定这

    12、个映射关系。如下所示: 编写业务逻辑到此,我们已经封装了一个名为Courses的表,并且配置完成。接下来的任务就是在Web应用开发中使用它们,为了演示在Hibernate中对数据库的不同类型的操作,我们开发的Web应用有以下的功能:增加一个Course;删除一个Course;按照Course的名字进行模糊搜索;查看系统中所有的Course。虽然我们可以直接在JSP中使用hibernate,但是往往我们不这样,而是把这些业务逻辑封装在JavaBean中,然后在JSP中通过调用JavaBean以访问Hibernate封装的对象。由于访问通过使用hibernate有一些共性的操作,在这里我们把这些共

    13、性的操作封装在一个专门的类中,这样其它的类可以继承它,如例程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 sessionFac

    14、tory;/会话工厂,用于创建会话 protected Session session;/hibernate会话 protected Transaction transaction; /hiberante事务 public HibernateBase()throws HibernateException this.initHibernate(); / 帮助方法 protected void initHibernate() throws HibernateException / 装载配置,构造SessionFactory对象 sessionFactory = new Configuration(

    15、).configure().buildSessionFactory(); /* *开始一个hibernate事务 */ protected void beginTransaction() throws HibernateException session = sessionFactory.openSession(); transaction = session.beginTransaction(); /* *结束一个hibernate事务。 */ protected void endTransaction(boolean commit) throws HibernateException if

    16、 (commit) mit(); else /如果是只读的操作,不需要commit这个事务。 transaction.rollback(); session.close(); 下面编写业务逻辑类,新建一个名为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.*; /*

    17、 *和course相关的业务逻辑 */ public class CourseBean extends HibernateBase public CourseBean()throws HibernateException super(); /* *增加一个Course */ public void addCourse(Course st)throws HibernateException beginTransaction(); session.save(st); endTransaction(true); /* *查询系统中所有的Course,返回的是包含有Course持久对象的Iterato

    18、r。 */ 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 Hiber

    19、nateException beginTransaction(); Course course=(Course)session.load(Course.class,id); session.delete(course); endTransaction(true); /* *按course的名字进行模糊查找,返回的是包含有Course持久对象的Iterator。 */ public Iterator getSomeCourse(String name)throws HibernateException String queryString = select c from Course as c

    20、where c.name like :name ; beginTransaction(); Query query = session.createQuery(queryString); query.setString(name, %+name+%); Iterator it= query.iterate(); return it; 在CourseBean封装了4个业务方法,你可以根据情况增加其它的业务方法。在CourseBean中,通过Hibernate来操作潜在的数据库资源。要保存Course数据到数据库,可以通过: session.save(Course); 方法来保存,它相当于使用在J

    21、DBC中执行以下语句: Connection con= Statement stmt=con.createStatement(); stmt.executeUpdate(insert into courses values(+course.getId(),+,+course.getName()+); con.close(); 可以看出,通过使用Hibernate,可以大大减少数据访问的复杂度。在JSP中调用业务逻辑添加数据CourseBean这个业务对象封装了和Hibernate的交互关系,从而使JSP和Hibernate关系的解藕。我们来看测试主页面的部分代码,如例程7所示。例程7 测试Hi

    22、bernate开发的应用(course.jsp) 成功添加了Course: name: Id: :增加一个course: id: name: :按名字模糊查找: name: :删除一个Course: id: :查看所有Course: 首先通过一个值对象Course(这个类正好是Hibernate使用的持久对象,这里作为值对象来传递数据)接收获得的参数,然后CourseBean的addCourse(Course)方法把数据保存到数据库。可以看出,通过使用Hibernate,把数据从表单中添加到数据库非常简单。查询下面来看模糊查找的JSP代码,如例程8所示。例程8 按名字模糊查找Course % try Iterator it=courseBusiness.getSomeCourse(String)request.getParameter(name); while(it.hasNext() Course temp=(Course)it.next(); out.println(+temp.getId()+); out.println(+temp.getName()+); catch(Exception e) out.println(e.get


    注意事项

    本文(使用Hibernate的一个完整例子.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开