hibernate + proxool配置
| |
技术文档>>JAVA>>新手入门>>基础入门>查看文档 |
|
| |
hibernate + proxool配置 |
|
| |
文章作者:未知 文章来源:水木森林 |
|
| |
查看:80次 录入:管理员--2007-11-17 |
|
| |
用hibernate自带的连接池性能不高,而且还存在bug。因此官方推荐使用c3p0或proxool连接池。 这里我介绍hibernate使用proxool连接池的配置:
首先配置proxool的配置文件,文件名:proxool.xml(当然,你也可以用资源文件)
<?xml version="1.0" encoding="utf-8"?> <!-- the proxool configuration can be embedded within your own application's. anything outside the "proxool" tag is ignored. --> <something-else-entirely> <proxool> <alias>dbpool</alias> <driver-url>jdbc:mysql://localhost:3306/webshop</driver-url> <driver-class>org.gjt.mm.mysql.driver</driver-class> <driver-properties> <property name="user" value="ycoe"/> <property name="password" value="123456"/> </driver-properties> <maximum-connection-count>10</maximum-connection-count> <house-keeping-test-sql>select current_date</house-keeping-test-sql> </proxool> </something-else-entirely>
这里有几点要说明的 <alias>是连接池的别名,在jdbc中可以用drivermanager.getconnection("proxool.dbpool");取得一个连接(但你得先在程序运行时先加载它)。
<driver-url>是数据库地址,不用说也明白了。后面也可以带一段参数useunicode=true&characterencoding=gb2312这是设定连接的参数,这里是定义了连接使用的编码为gb2312,这是为了解决数据库存取中的乱码问题(如果数据库没有提供编码设定的话,比如mysql5.0以前版本) <driver-class>这是jdbc使用的数据库驱动类,对于不同的数据库,有不同的驱动类支持,一般官方会提供 <driver-properties>里面的都很简单啦,不说了。
还有就是<maxmum-connection-count>是设置连接池内生成的最大连接数
proxool配置完成,把它放在web-infclasses下面(放在哪都没关系,只要让路径path包含着就行)!
下面是hibernate的配置:这里我们还是用xml文件,因为它配置映射有独特的昧力
hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?> <!doctype hibernate-configuration public "-//hibernate/hibernate configuration dtd 3.0//en" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration> <session-factory> <!-- database connection settings --> <property name="hibernate.connection.provider_class">org.hibernate.connection.proxoolconnectionprovider</property> <property name="hibernate.proxool.pool_alias">dbpool</property> <property name="hibernate.proxool.xml">proxool.xml</property> <!-- sql dialect --> <property name="dialect">org.hibernate.dialect.mysqldialect</property> <!-- echo all executed sql to stdout --> <property name="show_sql">false</property> <!-- drop and re-create the database schema on startup <property name="hbm2ddl.auto">create</property> --> <mapping resource="orders.hbm.xml"/> <mapping resource="users.hbm.xml"/> </session-factory> </hibernate-configuration>
hibernate3版本的配置都使用<property> 首先hibernate.connection.provider_class定义hibernate的连接加载类,这里proxool连接池是用这个,不同的连接池有不同的加载类,可以查阅hibernate文档获取相关信息 hibernate.proxool.pool_alias这里就是用我们上面提到的连接池的别名 hibernate.proxool.xml是向hibernate声明连接池的配置文件位置,可以用相对或绝对路径,用相对路径时要注意一定在要path范围内!不然会抛出异常。 dialect是声明sql语句的方言 show_sql定义是否显示hibernate生成的sql语言,一般在调试阶段设为true,完成后再改成false,这样有利于调试。 hbm2ddl.auto是声明是否使用hbm2 ddl工具,也就是根据映射文件生成sql的ddl文件。 <mapping >这个可是个好东西了,方便的用于映射。如果用资源文件的话就没有这个功能了.呵呵.resource是定义映射文件的位置,和proxool.xml一样。
不同的连接池用不同的配置,下面提供c3p0连接池在hibernate中的配置:
c3p0配置
<property name="hibernate.connection.provider_class">org.hibernate.connection.c3p0connectionprovider</property> <property name="hibernate.c3p0.max_size">20</property> <property name="hibernate.c3p0.min_size">5</property> <property name="hibernate.c3p0.timeout">120</property> <property name="hibernate.c3p0.max_statements">100</property> <property name="hibernate.c3p0.idle_test_period">120</property> <property name="hibernate.c3p0.acquire_increment">2</property>
好啦,到这里已经把proxool和hibernate的配置文件各项说明完了。 还有一个就是映射文件,在这里就不再说明了,挺多内容的,可以出一本书了。 孙卫琴的精通hibernate里面有很详细的说明
ps:《精通hibernate》电子工业出版社 这本书里面的东西在hibernate3里很多都不行的。hibernate3版本改了不少东西,连包名都改了。 这里想骂孙卫琴几句:拜托,不要一年出一本书行不行啊,花点时间,质量放高一点.太不厚道了,难为我把你出的书都认真了<<tomcat与java web开发技术详解>><<精通hibernate:java对象持久化技术详解>><<精通struts:基于mvc的java web设计与开发>>.对于初学者来说不错,但不够深度,用不着每本都用四五百页来写吧... 唉,要学这些技术,还是得去看看英文版的.
见: http://ycoe.cnblogs.com/archive/2006/03/20/353677.html
|
|
|
相关文档
|