关于服务器Tomcat和数据库MySQL的安装配置参见本人上一篇文章 《在Windows 2000 Server安装配置Tomcat+MySQL》
  在Tomcat上建立独立的服务myService  0.set %WebApp% = $Tomcat_HOME$/webapps/myService 1 在$Tomcat_HOME$/webapps下创建目录结构  myService    +-----WEB-INF       +-----lib       +-----class          +-----net             +-----sf                +-----hibernate                   +-----examples                      +-----quickstart 2 在Tomcat的server.xml($Tomcat_HOME$/conf)中为此服务配置独立的Context         <Context className="org.apache.catalina.core.StandardContext" cachingAllowed="true" charsetMapperClass="org.apache.catalina.util.CharsetMapper" cookies="true" crossContext="false" debug="0" displayName="Welcome to Tomcat" docBase="C:\Tomcat4.1\webapps\myService" mapperClass="org.apache.catalina.core.StandardContextMapper" path="/myService" privileged="false" reloadable="false" swallowOutput="false" useNaming="true" wrapperClass="org.apache.catalina.core.StandardWrapper">           <Resource name="jdbc/mysqltest" scope="Shareable" type="javax.sql.DataSource"/>           <ResourceParams name="jdbc/mysqltest">             <parameter>               <name>maxWait</name>               <value>5000</value>             </parameter>             <parameter>               <name>maxActive</name>               <value>4</value>             </parameter>             <parameter>               <name>password</name>               <value>test</value>             </parameter>             <parameter>               <name>url</name>               <value>jdbc:mysql://localhost:3306/study</value>             </parameter>             <parameter>               <name>driverClassName</name>               <value>com.mysql.jdbc.Driver</value>             </parameter>             <parameter>               <name>maxIdle</name>               <value>2</value>             </parameter>             <parameter>               <name>username</name>               <value>test</value>             </parameter>           </ResourceParams>    <ResourceLink name="jdbc/mysqltest" global="jdbc/mysqltest" type="javax.sql.DataSourcer"/>         </Context> 
3 解压下载的压缩包hibernate-2.1.2.zip,将解压出来的hibernate2.jar复制到%WebApp%/WEB-INF/lib  4 将解压出来的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 
5 编写hibernate配置文件hibernate.cfg.xml放在%WebApp%/WEB-INF/classes下  <?xml version='1.0' encoding='utf-8'?>  <!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/mysqltest</property>  <property name="show_sql">false</property>  <property name="dialect">net.sf.hibernate.dialect.MySQLDialect</property> 
 <!-- Mapping files -->  <mapping resource="Cat.hbm.xml"/> 
 </session-factory> 
 </hibernate-configuration>  *connection.datasource的名称必须和[Config Tomcat DBCP for Mysql]配置中server.xml的context指定的DBCP的名称一致。    6 编写第一个测试代码  6.1 将以下代码保存为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;   public class Cat { 
 private String id;  private String name;  private char sex;  private float weight; 
 public Cat() {  } 
 public String getId() {  return id;  } 
 private void setId(String id) {  this.id = id;  } 
 public String getName() {  return name;  } 
 public void setName(String name) {  this.name = name;  } 
 public char getSex() {  return sex;  } 
 public void setSex(char sex) {  this.sex = sex;  } 
 public float getWeight() {  return weight;  } 
 public void setWeight(float weight) {  this.weight = weight;  }  }   6.2 将以下代码保存为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> 
6.3 将以下代码保存为HibernateUtil.java,并生成相应的HibernateUtil.class,放入%WebApp%/WEB-INF/classes,同样注意package     package net.sf.hibernate.examples.quickstart;   import org.apache.commons.logging.Log;     import org.apache.commons.logging.LogFactory;   import net.sf.hibernate.*;   import net.sf.hibernate.cfg.*;   public class HibernateUtil { 
  private static Log log = LogFactory.getLog(HibernateUtil.class); 
  private static final SessionFactory sessionFactory; 
  static {   try {   // Create the SessionFactory   sessionFactory = new Configuration().configure().buildSessionFactory();   } catch (Throwable ex) {   log.error("Initial SessionFactory creation failed.", ex);   throw new ExceptionInInitializerError(ex);   }   } 
  public static final ThreadLocal session = new ThreadLocal(); 
  public static Session currentSession() throws HibernateException {   Session s = (Session) session.get();   // Open a new Session, if this Thread has none yet   if (s == null) {   s = sessionFactory.openSession();   session.set(s);   }   return s;   } 
  public static void closeSession() throws HibernateException {   Session s = (Session) session.get();   session.set(null);   if (s != null)   s.close();   }   } 
6.4 将以下代码保存为testcat.jsp,放入%WebApp%     <%@ 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">   <%    //添加一只Cat 
  Session ses = HibernateUtil.currentSession();   Transaction tx= ses.beginTransaction(); 
  Cat princess = new Cat();   princess.setName("chenm");   princess.setSex('F');   princess.setWeight(7.4f); 
  ses.save(princess);   tx.commit(); 
  HibernateUtil.closeSession(); 
  //读取库里所有Cat 
  ses = HibernateUtil.currentSession();   tx= ses.beginTransaction(); 
  Query query = ses.createQuery("select c from Cat as c where c.sex = :sex");   query.setCharacter("sex", 'F');   for (Iterator it = query.iterate(); it.hasNext();) {   Cat cat = (Cat) it.next();   out.println("Female Cat: " + cat.getName() );   } 
  tx.commit();   HibernateUtil.closeSession();   %>   </body>   </html> 
6.5 用http测试,http://localhost:8090/myService/testcat.jsp     测试结果,看见:Female Cat: chenm
    
 
  |