Hibernate支持第三方的连接池,官方推荐的连接池是C3P0,Proxool,以及DBCP.在配置连接池时需要注意的有三点:
成都创新互联服务项目包括南岔网站建设、南岔网站制作、南岔网页制作以及南岔网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,南岔网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到南岔省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已经不再推荐使用,官方的解释是这个连接池存在缺陷。如果你因为某种原因需要在Hibernate3中使用DBCP,建议采用JNDI方式。
二、默认情况下(即没有配置连接池的情况下),Hibernate会采用内建的连接池.但这个连接池性能不佳,且存在诸多BUG(笔者就曾在Mysql环境下被八小时连接悬空问题困扰过),因此官方也只是建议仅在开发环境下使用。
三、 Hibernate2和Hibernate3的命名空间有所变化.例如,配置C3P0时的provider_class有Hibernate2环境下使用 net.sf.hibernate.connection.C3P0ConnectionProvider,在Hibernate3环境下使用 org.hibernate.connection.C3P0ConnectionProvider。
下面是Hibernate环境下几种常见的连接池配置:
1.Hibernate默认连接池
Xml代码:
- version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> - >
name="connection.driver_class">com.mysql.jdbc.Driver name="connection.url"> - jdbc:mysql://localhost:3306/schoolproject
name="connection.useUnicode">true name="connection.characterEncoding">UTF-8 name="connection.username">root - >
name="connection.password"> name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" /> - version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> - >
name="connection.driver_class">com.mysql.jdbc.Driver name="connection.url"> - jdbc:mysql://localhost:3306/schoolproject
name="connection.useUnicode">true name="connection.characterEncoding">UTF-8 name="connection.username">root - >
name="connection.password"> name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" />
2.C3P0连接配置
Xml代码:
- version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> - >
name="connection.driver_class">com.mysql.jdbc.Driver name="connection.url"> - jdbc:mysql://localhost:3306/schoolproject
name="connection.useUnicode">true name="connection.characterEncoding">UTF-8 name="connection.username">root name="connection.password"> name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider name="hibernate.c3p0.max_size">20 name="hibernate.c3p0.min_size">5 name="hibernate.c3p0.timeout">120 name="hibernate.c3p0.max_statements">100 name="hibernate.c3p0.idle_test_period">120 name="hibernate.c3p0.acquire_increment">2 name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" /> - version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> - >
name="connection.driver_class">com.mysql.jdbc.Driver name="connection.url"> - jdbc:mysql://localhost:3306/schoolproject
name="connection.useUnicode">true name="connection.characterEncoding">UTF-8 name="connection.username">root name="connection.password"> name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider name="hibernate.c3p0.max_size">20 name="hibernate.c3p0.min_size">5 name="hibernate.c3p0.timeout">120 name="hibernate.c3p0.max_statements">100 name="hibernate.c3p0.idle_test_period">120 name="hibernate.c3p0.acquire_increment">2 name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" />
3.proxool连接池
(1) 先写proxool的配置文件,文件名:proxool.xml(一般放在与hibernate.cfg.xml文件在同一个目录中)本例配置的是MYSQL数据库,数据库的名字为schoolproject
Xml代码:
- version="1.0" encoding="UTF-8"?>
DBPool - jdbc:mysql://localhost:3306/schoolproject?useUnicode=true&characterEncoding=UTF8
- >
com.mysql.jdbc.Driver name="user" value="root"/> name="password" value=""/> 5 10 - version="1.0" encoding="UTF-8"?>
DBPool - jdbc:mysql://localhost:3306/schoolproject?useUnicode=true&characterEncoding=UTF8
- >
com.mysql.jdbc.Driver name="user" value="root"/> name="password" value=""/> 5 10
(2)配置hibernate.cfg.xml文件
Xml代码:
- version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> name="hibernate.connection.provider_class"> - org.hibernate.connection.ProxoolConnectionProvider
name="hibernate.proxool.pool_alias">DBPool name="hibernate.proxool.xml">proxoolconf.xml name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" /> - version='1.0' encoding='UTF-8'?>
- PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
> name="hibernate.connection.provider_class"> - org.hibernate.connection.ProxoolConnectionProvider
name="hibernate.proxool.pool_alias">DBPool name="hibernate.proxool.xml">proxoolconf.xml name="show_sql">true name="dialect">org.hibernate.dialect.MySQLDialect resource="com/wqbi/model/pojo/student.hbm.xml" />
(1) hibernate.connection.provider_class定义Hibernate的连接加载类,这里Proxool连接池是用这个,不同的连接池有不同的加载类,可以查阅Hibernate文档获取相关信息
(2) hibernate.proxool.pool_alias这里就是用我们上面提到的连接池的别名
(3) hibernate.proxool.xml是向Hibernate声明连接池的配置文件位置,可以用相对或绝对路径,用相对路径时要注意一定在要Path范围内!不然会抛出异常.
(4) dialect是声明sql语句的方言
(5) show_sql定义是否显示Hibernate生成的sql语言,一般在调试阶段设为true,完成后再改成false,这样有利于调试.
(6)
4.JNDI 连接池
数据源已经由应用服务配置好(如Web服务器),Hibernate需要做的只是通过JNDI名查找到此数据源.应用服务器将连接池对外显示为 JNDI绑定数据源,它是javax.jdbc.Datasource类的一个实例.只要配置一个Hibernate文件,如:
- hibernate.connection.datasource=java:/comp/env/jdbc/schoolproject //JNDI名
- hibernate.transaction.factory_class = org.hibernate.transaction.JTATransactionFactory
- hibernate.transaction.manager_loopup_class =
- org.hibernate.transaction.JBossTransactionManagerLookup
- hibernate.dialect=org.hibernate.dialect.MySQLDialect
网站标题:Hibernate2和Hibernate3连接池配置
文章路径:http://www.csdahua.cn/qtweb/news34/109334.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网