分享
 
 
 

简单的hibernate数据库插入例子(1)

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

简单的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 类,再在声明它的映射元数据。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有