简单的hibernate数据库插入例子
刚刚开始学习,希望和大家一起进步吧。请大家不要笑我。
这是一个最简单的例子,该例子基本上是按照hibernate reference来做的。
做这个例子我选用的应用服务器是山东中创软件商用中间件有限公司的InforWeb(这个应用服务器是商用的,如果你无法获得它,那么可以用tomcat代替),数据库我选用的是Oracle,你可以选用小巧的MySql。
首先你需要Hibernate2.0 相关运行环境,可以从 http://hibernate.org/下载;
第一步:下载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 提供带有缓冲池的JDBCConnections。如果你得到了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 类,再在声明它的映射元数据。