普通JAVA工程c3p0的配置使用

连线北海
连线北海
连线北海
201
文章
6
评论
2018年9月4日10:50:16 评论 577 3232字阅读10分46秒

C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。

今天介绍使用C3P0时各种配置方法,让你的程序快速使用C3P0的功能。

注意:这里介绍的是普通JAVA工程的配置方式,如果使用了框架(Spring),请参考其他方法,一般是在程序启动时加载配置文件,动态获取属性值注册连接池。

 

  • 第一种方式非常简单, 文件名字为:c3p0.properties(放在src目录下面)
c3p0.driverClass=com.mysql.jdbc.Driver
c3p0.jdbcUrl=jdbc:mysql://localhost:3308/database
c3p0.user=root
c3p0.password=root
package jdbc.mysql;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
 
import com.mchange.v2.c3p0.ComboPooledDataSource;
 
public class C3P0 {
    public static void main(String[] args) throws SQLException {
    	//数据库连接池默认会到classpath下去找数据库的配置。
        ComboPooledDataSource data = new ComboPooledDataSource();
        Connection conn = data.getConnection();
        String sql = "select * from table";
        PreparedStatement pstmt = conn.prepareStatement(sql);
        ResultSet rs = pstmt.executeQuery();
        while(rs.next()){
            System.out.println(rs.getString(1));
        }
    }
}
  • 第二种方式非常灵活好用,也非常接近于我们平时的hibernate和struts的配置文件方式而且可以为多个数据源提供服务,提供default-config和named-config两种配置方式 。其中里面的具体参数可参照c3p0文档(http://www.mchange.com/projects/c3p0/) 比较简单。根据属性名字几乎可以看出意思。
<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
  <default-config>
    <property name="user">root</property>
    <property name="password">1234</property>
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/database?characterEncoding=UTF-8&useOldAliasMetadataBehavior=true</property> 
    <property name="initialPoolSize">2</property>
    <property name="maxIdleTime">30</property>
    <property name="maxPoolSize">100</property>
    <property name="minPoolSize">2</property>
  </default-config>
   
  <named-config name="database">
    <property name="user">root</property>
    <property name="password">root</property>
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3308/database?characterEncoding=UTF-8&useOldAliasMetadataBehavior=true</property> 
    <property name="initialPoolSize">2</property>
    <property name="maxIdleTime">30</property>
    <property name="maxPoolSize">100</property>
    <property name="minPoolSize">2</property>
  </named-config>
 
</c3p0-config>
package jdbc.mysql;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.sql.DataSource;
 
import com.mchange.v2.c3p0.ComboPooledDataSource;
 
public class C3p0JDBC {
    public static void main(String[] args) throws SQLException {
        System.setProperty("com.mchange.v2.c3p0.cfg.xml",System.getProperty("user.dir")+"/config/c3p0-config.xml");
        //上面的配置文件  <default-config> 
        //默认情况下 构造函数传空值。会去找默认配置
        DataSource data = new ComboPooledDataSource();
        //上面的配置文件  <named-config name="database">
        //如果构造函数中传值,则找到对应的配置。
        DataSource data1 = new ComboPooledDataSource("database");
        Connection conn = data.getConnection();
        Connection conn1 = data1.getConnection();
        String sql = "select * from table";
        PreparedStatement pstmt = conn1.prepareStatement(sql);
        ResultSet rs = pstmt.executeQuery();
        while(rs.next()){
            System.out.println(rs.getString(1));
        }
    }
}
  • 这种配置是最不常用的,比较繁琐,就是把所有配置都写到程序里面来。
import com.mchange.v2.c3p0.*;
........    
ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass( "org.postgresql.Driver" ); //loads the jdbc driver            
cpds.setJdbcUrl( "jdbc:postgresql://localhost/testdb" );
cpds.setUser("dbuser");                                  
cpds.setPassword("dbpassword");                                  
 
cpds.setMaxStatements( 180 ); 
cpds.close();

 

继续阅读
weinxin
微信公众号
分享IT信息技术、北海生活的网站。提供北海本地化的信息技术服务。
连线北海
  • 本文由 发表于 2018年9月4日10:50:16
  • 除非特殊声明,本站文章均为原创,转载请务必保留本文链接
Java库之Lombok的妙用 JAVA编程

Java库之Lombok的妙用

Lombok是目前比较流行的Java库,Lombok能以简单的注解形式来简化Java代码,提高开发人员的开发效率,免去额外的getter或equals等方法,降低由于修改引起的维护成本,Lombok在...
【进阶】-Java读写文件锁 JAVA编程

【进阶】-Java读写文件锁

众所周知,Java中锁的概念是非常重要的,锁可以保证资源的安全可控,恰当使用锁即可使得资源高效利用,又能保证线程的安全访问,编程中在读取文件的时候常常碰到文件锁的使用,本文简单阐述文件锁在Java中的...
【基础】-Java访问控制 JAVA编程

【基础】-Java访问控制

访问控制 访问级别修饰符的作用是确定其他类是否可以使用特定字段或调用特定方法。 访问控制有两个级别: 在顶层级别 - public或package-private。 在成员级别 - public,pr...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: