首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >c3p0的常用配置方式

c3p0的常用配置方式

作者头像
用户5166556
发布2019-04-16 11:35:41
9520
发布2019-04-16 11:35:41
举报

1:第一种方式非常简单

c3p0.driverClass=com.mysql.jdbc.Driver
c3p0.jdbcUrl=jdbc:mysql://localhost:3308/database
c3p0.user=root
c3p0.password=root

文件名字为:c3p0.properties(放在src目录下面) //程序我写的比较简单,可以用来测试执行配置。

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));
		}
	}
}

2:第二种方式非常灵活好用,也非常接近于我们平时的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>

如果你把c3p0-config.xml放到src目录下面,那么你就不需要指定配置文件,它自动会找到这个配置文件,即在程序中不用写System.setProperty("com.mchange.v2.c3p0.cfg.xml",System.getProperty("user.dir")+"/config/c3p0-config.xml");这句话。

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));
		}
	}
}

3:这种配置是最不常用的,比较繁琐,就是把所有配置都写到程序里面来。

可选择性使用

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();
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2014年07月04日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档