简单的hibernate数据库插入例子

本文出自:http://blog.csdn.net/solarspot/archive/2004/06/16/21600.aspx

刚刚开始学习,希望和大家一起进步吧。请大家不要笑我。
这是一个最简单的例子,该例子基本上是按照 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  提供带有缓冲池的 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  类,再在声明它的映射元数据。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值