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

上传人:b****6 文档编号:19174715 上传时间:2023-01-04 格式:DOCX 页数:8 大小:21.83KB
下载 相关 举报
使用Hibernate的一个完整例子Word下载.docx_第1页
第1页 / 共8页
使用Hibernate的一个完整例子Word下载.docx_第2页
第2页 / 共8页
使用Hibernate的一个完整例子Word下载.docx_第3页
第3页 / 共8页
使用Hibernate的一个完整例子Word下载.docx_第4页
第4页 / 共8页
使用Hibernate的一个完整例子Word下载.docx_第5页
第5页 / 共8页
点击查看更多>>
下载资源
资源描述

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

《使用Hibernate的一个完整例子Word下载.docx》由会员分享,可在线阅读,更多相关《使用Hibernate的一个完整例子Word下载.docx(8页珍藏版)》请在冰豆网上搜索。

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

4、把Hibernate提供的hibernate2.jar和一些第三方的运行库拷贝到hibernate\WEB\INF\lib目录下。

(这些第三方的运行库包含在下载的Hibernatelib目录下)

5、在%TOMCAT_HOME%\conf\server.xml中Web应用和数据源。

在server.xml中加入以下的配置描述。

例程1配置web应用

<

Contextpath="

/hibernate"

docBase="

hibernate"

debug="

0"

reloadable="

true"

crossContext="

>

Resourcename="

jdbc/hibernate"

auth="

Container"

type="

javax.sql.DataSource"

/>

ResourceParamsname="

parameter>

name>

factory<

/name>

value>

mons.dbcp.BasicDataSourceFactory<

/value>

/parameter>

driverClassName<

org.gjt.mm.mysql.Driver<

url<

jdbc:

mysql:

///test<

username<

root<

password<

<

maxActive<

20<

maxIdle<

10<

maxWait<

-1<

/ResourceParams>

/Context>

在这里,配置了一个名为hibernate的Web应用,并且配置了一个数据源,数据源的JNDI名称为jdbc/hibernate。

您需要根据情况修改数据源的链接属性。

6、下一步就是书写Hibernate的配置描述符。

可以使用XML的配置描述,也可以使用基于属性的配置描述。

在这里使用基于XML的配置描述。

在hibernate\WEB-INF\classes目录下新建一个hibernate.cfg.xml文件。

然后加入例程2所示的内容。

!

DOCTYPEhibernate-configurationPUBLIC"

-//Hibernate/HibernateConfigurationDTD//EN"

"

hibernate-configuration>

session-factory>

propertyname="

connection.datasource"

java:

comp/env/jdbc/hibernate<

/property>

show_sql"

false<

dialect"

net.sf.hibernate.dialect.MySQLDialect<

--Mappingfiles-->

/session-factory>

/hibernate-configuration>

注意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"

hibernate-mapping>

classname="

com.hellking.study.hibernate.Course"

table="

Courses"

dynamic-update="

false"

>

idname="

id"

column="

CourseId"

string"

unsaved-value="

any"

generatorclass="

assigned"

/id>

name"

update="

insert="

Name"

/>

/class>

/hibernate-mapping>

在Course.hbm.xml映射文件中,指定了要映射的类和映射的表,并且指定了表的各个字段和Java对象中各个字段的映射关系,比如Course对象中的id属性对应了Courses表的courseId字段。

接下来的任务就是在hibernate.cfg.xml中指定这个映射关系。

如下所示:

…<

mappingresource="

Course.hbm.xml"

编写业务逻辑

到此,我们已经封装了一个名为Courses的表,并且配置完成。

接下来的任务就是在Web应用开发中使用它们,为了演示在Hibernate中对数据库的不同类型的操作,我们开发的Web应用有以下的功能:

增加一个Course;

删除一个Course;

按照Course的名字进行模糊搜索;

查看系统中所有的Course。

虽然我们可以直接在JSP中使用hibernate,但是往往我们不这样,而是把这些业务逻辑封装在JavaBean中,然后在JSP中通过调用JavaBean以访问Hibernate封装的对象。

由于访问通过使用hibernate有一些共性的操作,在这里我们把这些共性的操作封装在一个专门的类中,这样其它的类可以继承它,如例程5所示。

例程5HibernateBase.java

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

/***和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);

}/***按course的名字进行模糊查找,返回的是包含有Course持久对象的Iterator。

*/publicIteratorgetSomeCourse(Stringname)throwsHibernateException{StringqueryString="

selectcfromCourseascwherec.namelike:

;

query.setString("

"

%"

+name+"

);

在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"

%>

jsp:

useBeanid="

course"

class="

scope="

page"

setPropertyname="

property="

*"

/jsp:

useBean>

courseBusiness"

com.hellking.study.hibernate.CourseBean"

html>

body>

center>

%try{if(course.getId().equals(null)||course.getId().equals("

));

elsecourseBusiness.addCourse(course);

%>

成功添加了Course:

br>

name:

%=course.getName()%>

Id:

%=course.getId()%>

%}catch(Exceptione){}%>

hr>

:

增加一个course:

formaction="

course.jsp"

method="

get"

name="

add"

id:

inputtype=textname="

name:

inputtype=submitvalue="

submit"

/form>

:

按名字模糊查找:

queryCourse.jsp"

queryByName"

query"

删除一个Course:

deleteCourse.jsp"

delete"

ahref=viewAll.jsp>

查看所有Course:

a>

/body>

/html>

首先通过一个值对象Course(这个类正好是Hibernate使用的持久对象,这里作为值对象来传递数据)接收获得的参数,然后CourseBean的addCourse(Course)方法把数据保存到数据库。

可以看出,通过使用Hibernate,把数据从表单中添加到数据库非常简单。

查询

下面来看模糊查找的JSP代码,如例程8所示。

例程8按名字模糊查找Course

java.sql.*,java.util.*,com.hellking.study.hibernate.Course"

%try{Iteratorit=courseBusiness.getSomeCourse((String)request.getParameter("

while(it.hasNext()){Coursetemp=(Course)it.next();

out.println("

tr>

td>

+temp.getId()+"

/td>

+temp.getName()+"

/tr>

}}catch(Exceptione){out.println(e.get

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 生产经营管理

copyright@ 2008-2022 冰豆网网站版权所有

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