本文出自:http://blog.csdn.net/solarspot/archive/2004/06/16/21600.aspx
刚刚开始学习,希望和大家一起进步吧。请大家不要笑我。
这是一个最简单的例子,该例子基本上是按照
hibernate reference
来做的。
做这个例子我选用的应用服务器是山东中创软件商用中间件有限公司的
InforWeb(
这个应用服务器是商用的,如果你无法获得它,那么可以用
tomcat
代替
)
,数据库我选用的是
Oracle,
你可以选用小巧的
MySql
。
第一步:
下载
hibernate.
第二步:
在
InforWeb
的
deploy
(
tomcat
中是
webapps
)目录下先新建一个应用,目录如下:
%InforWebHome%/deploy/cat
。
第二步
:将数据库的驱动程序加入到
CLASSPATH
中,或者将驱动拷贝到
%InforWebHome%/lib
下(
tamcat
下是
%tomcatHome%/common/lib
);
第三步:
把
Hibernate
提供的
hibernate2.jar(
根目录下
)
和一些第三方的运行库拷贝到
hibernate/WEB/INF/lib
目录下。(这些第三方的运行库包含在下载的
Hibernate lib
目录下)。
下面对几个必须的包做一下解释:
dom4j:hibernate
解析
xml
配置和映射元文件时需要使用。
Cglib:hibernate
运行时使用这个代码生成库强化类。
Collections,Commons Logging
:
ODMG4
:
Hibernate
提供了一个可选的
ODMG
兼容持久化管理界面。如果你需要映射集合,你就需要这个类库,就算你不是为了使用
ODMG API
。我们在这
个教程中没有使用集合映射,但不管怎样把这个
JAR
拷贝过去总是不错
的。
虽然这几个文件是必须的,但是还是把所有的包都拷贝过去吧,这样比较保险啊,:)。
第四步:你可以通过
InforWeb
管理工具配置应用、给应用添加数据源,如果你对部署描述符比较熟悉的话就直接修改
server.xml
吧。这个文件在
conf
目录下,在其中加一个连接池的声明:
<Context path="/cat" docBase="cat">
<Resource name="jdbc/hibernate" scope="Shareable"
type="javax.sql.DataSource"/>
<ResourceParams name="jdbc/hibernate">
<parameter>
<name>factory</name>
<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
</parameter>
<!-- DBCP database connection settings -->
<parameter>
<name>url</name>
<value>jdbc:oracle:thin:@192.168.51.117:1521:bbs</value>
</parameter>
<parameter>
<name>driverClassName</name><value>oracle.jdbc.driver.OracleDriver</value>
</parameter>
<parameter>
<name>username</name>
<value>username</value>
</parameter>
<parameter>
<name>password</name>
<value>secret</value>
</parameter>
<!-- DBCP connection pooling options -->
<parameter>
<name>maxWait</name>
<value>3000</value>
</parameter>
<parameter>
<name>maxIdle</name>
<value>100</value>
</parameter>
<parameter>
<name>maxActive</name>
<value>10</value>
</parameter>
</ResourceParams>
</Context>
这个例子中我们要配置的上下文叫做
cat
,它位于
InforWeb/deploy/cat
目
录。要访问任何
Servlet,
在你的浏览器中访问
http://localhost:8080/cat
就可以
了。
InforWeb
在这个配置下,使用
DBCP
连接池,通过
JNDI
位置:
java:comp/env/jdbc/hibernate
提供带有缓冲池的
JDBC
Connection
s
。如果你得到了
JDBC
驱动的
exception
信息,请先不要用
Hibernate,
测试
JDBC
连接池本身是否正确。测试的一个简单的
jsp
如下:
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<%
Context initCtx = new InitialContext();
Context envCtx = (Context) initCtx.lookup("java:comp/env");
System.out.println("BBB::get jndi ok");
System.out.println("BBB::get datasource");
DataSource datasource = (DataSource) envCtx.lookup("/jdbc/hibernate");
System.out.println("BBB::get datasource OK");
System.out.println("BBB::get connection");
System.out.println("BBB::get connection");
Connection conn = datasource.getConnection();
System.out.println("BBB::get connection OK"+conn);
Statement stm = conn.createStatement();
System.out.println("get stm OK");
String sql = "select * from Courses";
ResultSet rs = stm.executeQuery(sql);
while(rs.next()){
out.println(rs.getString(1));
out.println("/n");
out.println(rs.getString(2));
}
%>
第四步
:在应用的
/WEB-INF
下建立
hibernate.cfg.xml
文件,它将绑定
JNDI
中提供的数据库连接池。内容如下:
<?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/hibernate</property>
<property name="show_sql">false</property>
<property name="dialect">net.sf.hibernate.dialect.OracleDialect</property>
<!-- Mapping files -->
<mapping resource="Cat.hbm.xml"/>
</session-factory>
</hibernate-configuration>
这个文件告诉
hibernate
如何获得
JNDI
提供的数据源
(
java:comp/env/jdbc/hibernate
),使用何种数据库方言(
DIalect
)
,
几种主流数据库方言的格式如下:
DB2:
net.sf.hibernate.dialect.DB2Dialect
Oracle:
net.sf.hibernate.dialect.OracleDialect
MySql:
net.sf.hibernate.dialect.MySQLDialect
Sybase:
net.sf.hibernate.dialect.SybaseSQLDialect
相信大家已经发现规律了,如果你使用了别的数据库就自己改一下吧(现在
hibernate
支持
16
中数据库,如果你用了自己的数据库……
^_^
)。
在
hibernate.cfg.xml
中的最后一个元素声明了
Cat.hbm.xml
是一个
Hibernate XML
映射文件,对应持久化类
Cat
。这个文件包含了把
POJO
类映射到数据库表(或多个数据库表)的元数据。让我们先编写这个
POJO
类,再在声明它的映射元数据。