与猫同乐(Tomcat+Hibernate)

这是一个Hibernate文档中的简单例子,环境是Tomcat+MySql+Hibernate

下载了Tomcat5.0,安装……

下载了Hibernate2,解包……

下载了MySql-nt5.0,安装……

下载数据库驱动mysql-connector-java-3.0.15-ga,解包……

数据库连接池配置:把数据库驱动mysql-connector-java-3.0.15-ga-bin.jar拷贝到%Tomcat%\common\lib下,在%Tomcat%\conf\server.xml里找到<Host>……</Host>,在其间添加

<Context path="/mytest" docBase="mytest" debug="0" reloadable="true" crossContext="true">

<Resource name="jdbc/mysql" auth="Container" type="javax.sql.DataSource"/>

<ResourceParams name="jdbc/mysql">

<parameter>

<name>factory</name>

<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>

</parameter>

<!-- MySQL dB username and password for dB connections -->

<parameter>

<name>username</name>

<value>root</value>

</parameter>

<parameter>

<name>password</name>

<value>root</value>

</parameter>

<parameter>

<name>driverClassName</name>

<value>org.gjt.mm.mysql.Driver</value>

</parameter>

<parameter>

<name>url</name>

<value>jdbc:mysql://localhost:3306/test</value>

</parameter>

<parameter>

<name>maxActive</name>

<value>100</value>

</parameter>

<parameter>

<name>maxIdle</name>

<value>30</value>

</parameter>

<parameter>

<name>maxWait</name>

<value>10000</value>

</parameter>

</ResourceParams>

</Context>

解释:Context里的path是应用程序的路径,就是%tomcat%\webapps下的目录。

然后配置Hibernate:

在%tomcat%\webapps下建一个mytest目录,以及相应的WEB-INF、classes、lib目录,将Hibernate2.jar拷到lib下,将Hibernate解包后的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

log4j还有一个properties文件要拷到classes目录下

在WEB-INF下的web.xml里添加数据库连接池的设置

<web-app>

<resource-ref>

<description>DB Connection</description>

<res-ref-name>jdbc/mysql</res-ref-name>

<res-type>javax.sql.DataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

</web-app>

这用来指明数据库连接池。然后是设置Hibernate使用这个容器管理的连接池来连接数据库:在classes目录下建一个hibernate.cfg.xml,写入

<?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/mysql</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>

这里可以看到连接的设置,其中dialect是用来指明一个类,来处理数据库数据类型和Java数据类型之间的对照的。<mapping resource="Cat.hbm.xml"/>是映射设置,下面会提到。先看看根据数据库表结构制作的java bean:

数据库结构为:CAT

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)

对应的java bean源程序:

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;

}

}

然后在classes目录下创建一个Cat.cfg.xml来配置PO对象:

<?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>

在这里可以看到java bean类net.sf.hibernate.examples.quickstart.Cat和数据库表CAT的映射关系。

编译好Cat类,放到相应目录下,OK,配置就完成了。下面是在JSP里应用的例子。

首先我们再创建一个类HibernateUtil,用来处理一些诸如取/关Session的功能,这些功能也可以直接写在JSP里:

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();

}

}

然后是Cat.JSP,很简单

<%@ 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("ahxu");

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>

今天,学习了cvs的安装、建库、checkout

安装:set CVSROOT=:local:d:\src\master

建库:$ cvs init

放置需要版本控制的文件:$ cvs import -m "test distribution" ccvs CVS_DIST CVS-TEST

checkout:$ cd

         $ cvs checkout ccvs

知道了cvs可以有效的控制并发改写源文件,每个人都可以同时修改源文件并提交,cvs可以有条件的合并每个人的修改。

而原来的版本控制程序当一个人checkout后,别人就不能checkout,只有等前一个checkin后,别人才可以checkout.

6天

下周会是特别忙,几场考试都撞车了。

除了这次软件设计师,还有汇编,马克思,软件工程,rose。

我也有差不多一个星期没有看软设了,这回心里没有太多把握。

六级考试到现在还没有开始复习。

要做的事真是太多了。

不过我最怕无聊,看来至少这一段时间是没有机会无聊了。

8天了。

 马上要考试了,不只是软设,还有汇编,软件工程,马克思,rose一共四门科目。

我要复习的太多了。昨天,把软件工程的课程设计做好了,虽然还有几个地方要完善,不过已经颇具规模了。

昨天在csdn的博可站点发了篇文章,感兴趣的可以看看。关于linux的话题。

10天了!--听侯捷的讲座

这两天,我已经不再复习软件考试了,一方面是时间太忙,好多科目要考试,另一方面是自己有些悲观。再加上要完善一个玩具级的小程序,一天到晚的敲键盘。

星期天到华中科技大学听侯捷先生的讲座,收获颇多,我将见闻写在了在csdn的博客上面,现在被csdn置在首页,有兴趣的可以看看。

解决:jsp页面中文显示问题

    问题:http://www.learndiary.com/disDiaryContentAction.do?goalID=267

日记标题 问题:jsp中文显示,<c:set>的值可否是对象?meta标记  作者: admin  创建时间: 2004-10-21 21:52:13 

在论坛上解决了这个问题,结果竟是如此简单:加上<%@ page pageEncoding="gb2312" %>,决定jsp页面编写时的编码。<%@ page content_type="text/html;charset=UTF-8" %>,决定jsp页面显示在客户端浏览器的编码。

    在解决这个问题的同时,我还发现了一篇至今为止我所见过的解决java中文问题最彻底的文章: 

    上篇:http://www.pconline.com.cn/pcedu/empolder/gj/java/0404/366404.html

    下篇:http://www.pconline.com.cn/pcedu/empolder/gj/java/0405/368760.html

    我还没有好好的来理解这篇文章,应该结合java的国际化方案好好的学习一下这篇文章。 

14天!好快啊

      昨天感冒了,整个晚上都在发烧,影响了复习进度。再加上最近有好多科目要考试,真是焦头烂额啊。

      明天把上午题复习完,转入下午题。

      昨天的汇编试验报告简直不是不堪入目,我都不好意思写名字了。

      下午完善一个小程序,其中使用到了mysql数据库。我保证程序是对的,但是从SQLException中getMessage()得到的信息是: null,  message from server: "#HY000Host 'localhost.localdomain' is not allowed to connect to this MySQL server",为什么会拒绝呢?想不通。

      前天和昨天都不能登陆,不知道什么原因。所以直到现在才来更新。

问题:jsp中文显示,的值可否是对象?me

    (注:这个问题已解决:见:http://www.learndiary.com/disDiaryContentAction.do?goalID=292)

   1、直接写在jsp页面的中文显示不正常,用“native2ascii -encoding gb2312 old.jsp new.jsp"也不行,gb2312换成utf-8也不行,

但是,在<% out.println(用“native2ascii -encoding gb2312 old.jsp new.jsp”) %>却正常,在javascript里显示的此类处理过的中文也正常,

我是按照网上别人的方法试的,但是就是不行,明天再试试。

    2、jstl中的<c:set>标签的值是否可为自定义的对象还不清楚?

见下:

来自:jbas, 时间:2004-10-19 13:42:00, ID:2854482 [显示:小字体 | 大字体] 

这是我程序的一部分:

<jsp:useBean id="idCommunity" class="com.beltino.communitymedical.community.Community" scope="page" />

<c:set var="id" value="${param.id}"/>

<c:set var="action" value="${param.action}"/>

<c:set var="retList"/>

<c:if test="${empty id}">

   <c:set var="action" value="new"/>

</c:if>

<c:if test="${!empty id}">

   <c:set var="action" value="edit"/>

   /*用inCommunity中含有“return this;”的方法getCommunityInformation(id)返回类Community的一个

    *对象,这个对象的唯一标识ID是"id".

    */

   <c:set var="idCommunity" value="${idCommunity.getCommunityInformation(id)}"/>  //有问题

   /*返回这个对象的子对象的一个列表retList*/

   <c:set var="retList" value="${idCommunity.getCommunityChildByPId(id)}"/>

</c:if>

........

现在 <c:set var="idCommunity" value="${idCommunity.getCommunityInformation(id)}"/>这样写有问题,页面提示出错:

org.apache.jasper.JasperException: /webapp/community/editCommunity.jsp(24,3) The function getCommunityInformation must be used with a prefix when a default namespace is not specified

可是如果我在resin下可以的。如果我调用不带参数的也是可以的

3、在jsp+struts页面中怎么样加meta标记呢?如果转换成了utf-8, 这个meta还起作用吗?我不知道。