Hibernate各类概念-C3P0数据库连接池配置办法

建立数据库连接时比较消耗时间的,所以通常都会采用数据库连接池的技术来建立多条数据库连接,并且在将来持续使用,从而节约掉建立数据库连接的时间 
hibernate本身是提供了数据库连接池的,但是hibernate官网也不推荐使用他自带的数据库连接池。 
一般都会使用第三方的数据库连接池 
C3P0是免费的第三方的数据库连接池,并且有不错的表现 
可以下载c3p0的jar包 
c3p0-0.9.1.jar

注:当运行次数不大的时候,从运行效果上来看,是看不出区别的。 只有在高并发量的情况下,才会体会出来。本知识主要是提供这个相关配置办法,以供以后有需要的时候,查询与修改方便。 

  • jar包

    记得导入c3p0专用的jar包
  • 进行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">50000</property> 
            <property name="hibernate.c3p0.max_statements">100</property> 
            <property name="hibernate.c3p0.idle_test_period">3000</property> 
            <!-- 当连接池耗尽并接到获得连接的请求,则新增加连接的数量 -->
            <property name="hibernate.c3p0.acquire_increment">2</property> 
            <!-- 是否验证,检查连接 -->
            <property name="hibernate.c3p0.validate">false</property>   
    即:
    <?xml version='1.0' encoding='utf-8'?>
    <!DOCTYPE hibernate-configuration PUBLIC
           "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
      
    <hibernate-configuration>
      
        <session-factory>
            <!-- Database connection settings -->
            <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
            <property name="connection.url">jdbc:mysql://localhost:3306/test?characterEncoding=GBK</property>
            <property name="connection.username">root</property>
            <property name="connection.password">admin</property>
            <!-- SQL dialect -->
            <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
            <property name="current_session_context_class">thread</property>
            <property name="show_sql">true</property>
            <property name="hbm2ddl.auto">update</property>
              
            <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">50000</property> 
            <property name="hibernate.c3p0.max_statements">100</property> 
            <property name="hibernate.c3p0.idle_test_period">3000</property> 
            <!-- 当连接池耗尽并接到获得连接的请求,则新增加连接的数量 -->
            <property name="hibernate.c3p0.acquire_increment">2</property> 
            <!-- 是否验证,检查连接 -->
            <property name="hibernate.c3p0.validate">false</property>           
              
            <mapping resource="com/how2java/pojo/Product.hbm.xml" />
            <mapping resource="com/how2java/pojo/Category.hbm.xml" />
            <mapping resource="com/how2java/pojo/User.hbm.xml" />
              
        </session-factory>
      
    </hibernate-configuration>
  • 测试

    注:当运行次数不大的时候,从运行效果上来看,是看不出区别的。 只有在高并发量的情况下,才会体会出来。本知识主要是提供这个相关配置办法,以供以后有需要的时候,查询与修改方便。

    import org.hibernate.Session;
    import org.hibernate.SessionFactory;
    import org.hibernate.cfg.Configuration;
       
    public class TestHibernate {
        public static void main(String[] args) {
            SessionFactory sf = new Configuration().configure().buildSessionFactory();
       
            Session s = sf.openSession();
            s.beginTransaction();
       
            s.createQuery("from Category").list();
               
            s.getTransaction().commit();
            s.close();
            sf.close();
        }
    }
    
  • c3p0多并发时,性能急剧下降。推荐用druid




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值