hibernate的手册里的cat例子感觉很不明了,很难照着它轻松的运行起第一个例子,费了点周折,总算看到一点结果,如果你是新手,可以参考一下,少走一些弯路。
1.下载tomcat和hibernate
tomcat 5.0.27 | tomcat 5.0.28 | hibernate2.1.6
2. 安装
以tomcat+mysql+hibernate为例
tomcat的安装,及mysql的安装和dbcp的配制参见
http://blog.csdn.net/ahxu/archive/2004/09/01/91611.aspx,这里就不提了,这里假设tomcat+mysql已经配置并测试可用,这里%webapp%代表你已配置好的一个web应用的root,着重说一下hibernate的安装,
1) 解压下载的压缩包,将解压出来的hibernate2.jar复制到%webapp%/web-inf/lib
2) 将解压出来的lib目录下的
cglib-full-2.0.2.jar
commons-collections-2.1.1.jar
commons-logging-1.0.4.jar
dom4j-1.4.jar
ehcache-0.9.jar
jta.jar
log4j-1.2.8.jar
odmg-3.0.jar
文件同样复制到%webapp%/web-inf/lib,具体请参见解压出来的lib目录下的readme.txt。
3) 将解压出来的etc目录下的
log4j.properties
文件复制到%webapp%/web-inf/classes。
3.编写相关文件
1) 按照参考文档,配置hibernate,将以下代码保存为hibernate.cfg.xml放在%webapp%/web-inf/classes下
<?xml version='1.0' encoding='utf-8'?> <session-factory> |
<property name="connection.datasource">java:comp/env/jdbc/mysql</property> <!-- mapping files --> </session-factory> </hibernate-configuration> |
note:这里与hibernate文档里的不一样,这里指定数据源为mysql数据库jdbc/mysql,方言dialect为net.sf.hibernate.dialect.mysqldialect。
2) 将以下代码保存为cat.java,并生成相应的cat.class,放入%webapp%/web-inf/classes,这里无论你用什么方法生成cat.class,但最终cat.class应在%webapp%/web-inf/classes/net/sf/hibernate/examples/quickstart目录下
package net.sf.hibernate.examples.quickstart; private string id; public cat() { public string getid() { private void setid(string id) { public string getname() { public void setname(string name) { public char getsex() { |
public void setsex(char sex) { public float getweight() { public void setweight(float weight) { } |
3) 将以下代码保存为o/r映射文件cat.hbm.xml,放入%webapp%/web-inf/classes
| <?xml version="1.0"?> <!doctype hibernate-mapping public "-//hibernate/hibernate mapping dtd//en" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> <hibernate-mapping> <class name="net.sf.hibernate.examples.quickstart.cat" table="cat"> <!-- a 32 hex character is our surrogate key. it's automatically generated by hibernate with the uuid pattern. --> <id name="id" type="string" unsaved-value="null" > <column name="cat_id" sql-type="char(32)" not-null="true"/> <generator class="uuid.hex"/> </id> <!-- a cat has to have a name, but it shouldn' be too long. --> <property name="name"> <column name="name" length="16" not-null="true"/> </property> <property name="sex"/> <property name="weight"/> </class> </hibernate-mapping |
4) 在数据库内建表,结构如下
column | type | modifiers
--------+-----------------------+-----------
cat_id | character(32) | not null
name | character varying(16) | not null
sex | character(1) |
weight | real |
indexes: cat_pkey primary key btree (cat_id)
5) 将以下代码保存为hibernateutil.java,并生成相应的hibernateutil.class,放入%webapp%/web-inf/classes,同样注意package
package net.sf.hibernate.examples.quickstart; private static log log = logfactory.getlog(hibernateutil.class); private static final sessionfactory sessionfactory; static { public static final threadlocal session = new threadlocal(); public static session currentsession() throws hibernateexception { public static void closesession() throws hibernateexception { |
note:这里与hibernate文档也不同,原文档编绎时缺少2个包,这里已加上。
6) 将以下代码保存为test.jsp,放入%webapp%/,用http测试
<%@ page language="java" pageencoding="gb2312" %><%@ page import="net.sf.hibernate.transaction"%><%@ page import="net.sf.hibernate.session"%><%@ page import="net.sf.hibernate.cfg.*"%><%@ page import="net.sf.hibernate.query"%><%@ page import="net.sf.hibernate.examples.quickstart.hibernateutil"%><%@ page import="net.sf.hibernate.examples.quickstart.cat"%><%@ page import="java.util.*"%><!doctype html public "-//w3c//dtd html 4.0 transitional//en"><html><head><title>lomboz jsp</title></head><body bgcolor="#ffffff"> session ses = hibernateutil.currentsession(); cat princess = new cat(); ses.save(princess); hibernateutil.closesession(); //读取库里所有cat ses = hibernateutil.currentsession(); query query = ses.createquery("select c from cat as c where c.sex = :sex"); tx.commit(); |
小结
步骤基本与原文档步骤相同,只是做了一些补充,方便上手,这里并没有对其中的一些配置做具体解释,如有疑问请参见发行包中的相关文档。
以上tomcat5.027 + hibernate2.1.6测试通过
闽公网安备 35060202000074号