Proxool+Spring+Hibernate

spring,hibernate,proxool的整合

在hibernate中使用proxool非常简单,只需要把hibernate.cfg.xml中的数据库配置改一改就可以了.

默认的是:

[xhtml]  view plain copy
  1. <hibernate-configuration>  
  2.  <session-factory>  
  3.   <property name="connection.driver_class">com.mysql.jdbc.Driver</property>   
  4.   <property name="connection.url">jdbc:mysql://200.200.1.249/activemq</property>   
  5.   <property name="connection.username">root</property>   
  6.   <property name="connection.password">root</property>   
  7.     
  8.   <property name="show_sql">true</property>  
  9.   <property name="dialect">org.hibernate.dialect.HSQLDialect</property>   
  10.     
  11.   <mapping resource="test.hbm.xml"/>  
  12.   ...(resource)  
  13.     
  14.  </session-factory>  
  15. </hibernate-configuration>  
 

改为:

[xhtml]  view plain copy
  1. <hibernate-configuration>  
  2.  <session-factory>  
  3.   <property name="proxool.pool_alias">jms1</property>  
  4.      <property name="proxool.xml">proxool.xml</property>  
  5.      <property name="connection.provider_class">  
  6.          org.hibernate.connection.ProxoolConnectionProvider  
  7.      </property>  
  8.     
  9.   <property name="show_sql">true</property>  
  10.   <property name="dialect">org.hibernate.dialect.HSQLDialect</property>   
  11.     
  12.   <mapping resource="Customer.hbm.xml"/>  
  13.   ...(resource)  
  14.     
  15.  </session-factory>  
  16. </hibernate-configuration>  
 

当然,需要写一个proxool的配置文件proxool.xml

new Configuration().configure().buildSessionFactory()打开的SessionFactory调用的是连接池创建的数据库连接.

 

 

在spring中使用proxool:

[xhtml]  view plain copy
  1. <bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource" destroy-method="close">  
  2.  <property name="driver" value="com.mysql.jdbc.Driver" />  
  3.     <property name="driverUrl" value="jdbc:mysql://localhost/activemq?user=root&password=root" /><!--必须在这里配置用户名/密码,下面的貌似没用-->  
  4.     <property name="user" value="root" />  
  5.     <property name="password" value="root" />  
  6.     <property name="alias" value="jms1" />  
  7.     <property name="houseKeepingSleepTime" value="90000" />  
  8.     <property name="prototypeCount" value="5" />  
  9.     <property name="maximumConnectionCount" value="100" />  
  10.     <property name="minimumConnectionCount" value="10" />  
  11. </bean>  
 

 

 

 

再说说spring,hibernate,与proxool的集成

当spring与hibernate整合时,SessionFactory是由org.springframework.orm.hibernate3.LocalSessionFactoryBean来创造的

直接使用jdbc创建数据库连接:

[xhtml]  view plain copy
  1. <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">    
  2.  <property name="driverClassName" value="com.mysql.jdbc.Driver" />  
  3.  <property name="url" value="jdbc:mysql://localhost/activemq" />  
  4.  <property name="username" value="root" />    
  5.  <property name="password" value="root" />  
  6. </bean>  
  7. <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">    
  8.     <property name="dataSource" ref="dataSource" />  
  9.     <property name="hibernateProperties">  
  10.         <props>  
  11.             <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>  
  12.             <prop key="hibernate.show_sql">true</prop>  
  13.             <prop key="hibernate.cache.use_query_cache">true</prop>  
  14.             <!--<prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>-->  
  15.         </props>  
  16.     </property>  
  17.     <property name="mappingLocations">    
  18.         <list>    
  19.             <value>Customer.hbm.xml</value>    
  20.    ...(resource)  
  21.         </list>    
  22.     </property>    
  23. </bean>  
 

 

使用proxool创建的数据库连接池:

[xhtml]  view plain copy
  1. <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
  2.  <property name="hibernateProperties">  
  3.   <props>  
  4.    <prop key="hibernate.dialect">org.hibernate.dialect.HSQLDialect</prop>  
  5.    <prop key="hibernate.show_sql">true</prop>  
  6.    <prop key="hibernate.cglib.use_reflection_optimizer">true</prop>  
  7.    <prop key="connection.provider_class">org.hibernate.connection.ProxoolConnectionProvider</prop>  
  8.    <prop key="hibernate.proxool.xml">proxool.xml</prop>  
  9.    <prop key="hibernate.proxool.pool_alias">jms1</prop>  
  10.       
  11.   </props>  
  12.  </property>  
  13.  <property name="mappingResources">  
  14.   <list>  
  15.    <value>Customer.hbm.xml</value>  
  16.    ...(resource)  
  17.   </list>  
  18.  </property>  
  19. </bean>  

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值