先看官网给的范例:

  1. import java.sql.*;
  2. import javax.naming.*;
  3. import javax.sql.DataSource;
  4. import com.mchange.v2.c3p0.DataSources;
  5.  
  6. /**
  7. * This example shows how to acquire a c3p0 DataSource and
  8. * bind it to a JNDI name service.
  9. */
  10. public final class JndiBindDataSource
  11. {
  12. // be sure to load your database driver class, either via
  13. // Class.forName() [as shown below] or externally (e.g. by
  14. // using -Djdbc.drivers when starting your JVM).
  15. static
  16. {
  17. try
  18. { Class.forName( "com.mysql.jdbc.Driver" ); }
  19. catch (Exception e)
  20. { e.printStackTrace(); }
  21. }
  22.  
  23. public static void main(String[] argv)
  24. {
  25. try
  26. {
  27. // let a command line arg specify the name we will
  28. // bind our DataSource to.
  29. String jndiName = argv[0];
  30.  
  31. // acquire the DataSource using default pool params...
  32. // this is the only c3p0 specific code here
  33. DataSource unpooled = DataSources.unpooledDataSource("jdbc:mysql://127.0.0.1:3306/gpsdata",
  34. "root",
  35. "root");
  36. DataSource pooled = DataSources.pooledDataSource( unpooled );
  37.  
  38. // Create an InitialContext, and bind the DataSource to it in
  39. // the usual way.
  40. //
  41. // We are using the no-arg version of InitialContext's constructor,
  42. // therefore, the jndi environment must be first set via a jndi.properties
  43. // file, System properties, or by some other means.
  44. InitialContext ctx = new InitialContext();
  45. ctx.rebind( jndiName, pooled );
  46. System.out.println("DataSource bound to nameservice under the name \"" +
  47. jndiName + '\"');
  48. }
  49. catch (Exception e)
  50. { e.printStackTrace(); }
  51. }
  52.  
  53. static void attemptClose(ResultSet o)
  54. {
  55. try
  56. { if (o != null) o.close();}
  57. catch (Exception e)
  58. { e.printStackTrace();}
  59. }
  60.  
  61. static void attemptClose(Statement o)
  62. {
  63. try
  64. { if (o != null) o.close();}
  65. catch (Exception e)
  66. { e.printStackTrace();}
  67. }
  68.  
  69. static void attemptClose(Connection o)
  70. {
  71. try
  72. { if (o != null) o.close();}
  73. catch (Exception e)
  74. { e.printStackTrace();}
  75. }
  76.  
  77. private JndiBindDataSource()
  78. {}
  79. }

1.建立 com.mchange.v2.c3p0.ComboPooledDataSource

这是一个JavaBean,在使用前应设置它的jdbcURL、user、password和driverClass。其他参数参考configuration properties

[java] view
plain
copy

  1. ComboPooledDataSource cpds = new ComboPooledDataSource(); cpds.setDriverClass( "org.postgresql.Driver" );
  2. cpds.setJdbcUrl( "jdbc:postgresql://localhost/testdb" ); cpds.setUser("swaldman");
  3. cpds.setPassword("test-password");
  4. // 下面的设置是可选的,c3p0可以在默认条件下工作,也可以设置其他条件
  5. cpds.setMinPoolSize(5);
  6. cpds.setAcquireIncrement(5);
  7. cpds.setMaxPoolSize(20);

也可以使用命名Configuration

[java] view
plain
copy

  1. ComboPooledDataSource cpds = new ComboPooledDataSource("intergalactoApp");

2.使用工厂类com.mchange.v2.c3p0.DataSources

com.mchange.v2.c3p0.DataSources 可以按照传统的JDBC驱动建立一个无连接池的DataSource,然后转化为连接池的DataSource。

[java] view
plain
copy

  1. DataSource ds_unpooled = DataSources.unpooledDataSource("jdbc:postgresql://localhost/testdb", "swaldman", "test-password");
  2. DataSource ds_pooled = DataSources.pooledDataSource( ds_unpooled );
  3. // 此时DataSource已经可以使用,但应该显示的设置driver Class
  4. Class.forName("org.postgresql.Driver");

如果想设置其中的参数,可以将参数放入一个Map中

[java] view
plain
copy

  1. DataSource ds_unpooled = DataSources.unpooledDataSource("jdbc:postgresql://localhost/testdb", "swaldman", "test-password");
  2. Map overrides = new HashMap();
  3. overrides.put("maxStatements", "200"); overrides.put("maxPoolSize", new Integer(50));
  4. //建立一个包括默认值和设置值的PooledDataSource
  5. ds_pooled = DataSources.pooledDataSource( ds_unpooled, overrides );

如果使用命名的Configuration,可以如下

[java] view
plain
copy

  1. ds_pooled = DataSources.pooledDataSource( ds_unpooled, "intergalactoAppConfig", overrides );

销毁DataSource有两种方式

DataSource.destroy()方式

[java] view
plain
copy

  1. DataSource ds_pooled = null;
  2. try {
  3. DataSource ds_unpooled = DataSources.unpooledDataSource("jdbc:postgresql://localhost/testdb", "swaldman", "test-password");
  4. ds_pooled = DataSources.pooledDataSource( ds_unpooled );
  5. // 下面正常使用DataSource...
  6. }
  7. finally {
  8. DataSources.destroy( ds_pooled );
  9. }

另一种是PooledDataSource 接口提供的close() 方法

[java] view
plain
copy

  1. static void cleanup(DataSource ds) throws SQLException {
  2. // 确定是否为c3p0的PooledDataSource
  3. if ( ds instanceof PooledDataSource) {
  4. PooledDataSource pds = (PooledDataSource) ds;
  5. pds.close();
  6. } else
  7. System.err.println("Not a c3p0 PooledDataSource!");
  8. }

Java中使用C3P0连接池的更多相关文章

  1. Spring框架中 配置c3p0连接池 完成对数据库的访问

    开发准备: 1.导入jar包: ioc基本jar jdbcTemplate基本jar c3p0基本jar 别忘了mysql数据库驱动jar 原始程序代码:不使用配置文件方式(IOC)生成访问数据库对象 ...

  2. JAVA中事物以及连接池

    一.事物 什么是事物? 事务,一般是指要做的或所做的事情.在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元.这些单元要么全都成功,要么全都不成功. 做一件事情,这个一件事情中有多个 ...

  3. java学习笔记—c3p0连接池与元数据分析(42)

    第一步:导入c3p0包 第二步:在classpath目录下,创建一个c3p0-config.xml <?xml version="1.0" encoding="UT ...

  4. Spring框架中 配置c3p0连接池

    开发准备: 1.导入jar包: ioc基本jar jdbcTemplate基本jar c3p0基本jar 别忘了mysql数据库驱动jar 原始程序代码:不使用配置文件方式(IOC)生成访问数据库对象 ...

  5. Hibernate的配置中,c3p0连接池相关配置

    一.配置c3p0 1.导入 hibernate-c3po连接池包,Maven地址是:http://mvnrepository.com/artifact/org.hibernate/hibernate- ...

  6. C3P0连接池在hibernate和spring中的配置

    首先为什么要使用连接池及为什么要选择C3P0连接池,这里就不多说了,目前C3P0连接池还是比较方便.比较稳定的连接池,能与spring.hibernate等开源框架进行整合. 一.hibernate中 ...

  7. Spring之c3p0连接池配置和使用

    1.导入包:c3p0和mchange包 2.代码实现方式: package helloworld.pools; import com.mchange.v2.c3p0.ComboPooledDataSo ...

  8. C3P0连接池工具类实现步骤及方法

    C3P0连接池的工具类 使用C3P0获得连接对象连接池有一个规范接口 javax.sal.DataSourse 接口定义了一个从连接池中获得连接的方法getConnection(); 步骤导入jar包 ...

  9. (七)Spring 配置 c3p0 连接池

    目录 在 Spring 核心配置文件中配置 c3p0 连接池 配置 JdbcTemplate 对象 在 service 层注入 userDao 在 UserDao 里面注入 JdbcTemplate ...

随机推荐

  1. Android实现分享图片和文字的功能

    为了应用的推广,我们经常看到点击分享按钮会出现,比如微博微信等应用的分享二等列表,这是如何实现的呢?这一篇将要详细的介绍. android的实现分享是通过隐式的启动activity. 分享文本 1.a ...

  2. 自定义控件辅助神器ViewDragHelper

    ViewDragHelper作为官方推出的手势滑动辅助工具,极大的简化了我们对手势滑动的处理逻辑,v4包中的SlidingPaneLayout和DrawerLayout内部都有ViewDragHelp ...

  3. 今天我点亮了CSDN博客专家殊荣

    很久以前,看着csdn博客学习第一篇博客时,我依旧记得,是一个名叫蒋老夫子的博客专家,文章写的非常认真.内心很崇拜.在想,若干年后,在哪个地方?以什么样的一种状态,也得到此殊荣,华为有句口号,叫勇敢做 ...

  4. UNIX网络编程——UDP回射服务器程序(初级版本)以及漏洞分析

    该函数提供的是一个迭代服务器,而不是像TCP服务器那样可以提供一个并发服务器.其中没有对fork的调用,因此单个服务器进程就得处理所有客户.一般来说,大多数TCP服务器是并发的,而大多数UDP服务器是 ...

  5. MyEclipse2014搭建JSF项目实例

    开发环境:  Windows2008 R2 64位 + MyEclipse Professional 2014 +JDK1.7+Tomcat7.0 搭建步骤: 1.打开MyEclipse2014后新建 ...

  6. 03 Button 按钮

    按钮   父类: TextView     >概念:可以被按,点击 并且执行一个动作     >属性:         在按钮内部的上下左右设置图片:             androi ...

  7. Log file location for Oracle E-Business Suite R12

    Log file location in Oracle E-Business Suite R12 - Apache, OC4J and OPMN: $LOG_HOME/ora/10.1.3/Apach ...

  8. Java进阶(六)Java反射机制可恶问题NoSuchFieldException

    作为一种重要特性,Java反射机制在很多地方会用到.在此做一小结,供朋友们参考. 首先从一个问题开始着手. 可恶的问题又来了,NoSuchFieldException,如下图所示: 完全不知道这个qu ...

  9. Android性能优化之常见的内存泄漏

    前言 对于内存泄漏,我想大家在开发中肯定都遇到过,只不过内存泄漏对我们来说并不是可见的,因为它是在堆中活动,而要想检测程序中是否有内存泄漏的产生,通常我们可以借助LeakCanary.MAT等工具来检 ...

  10. 【一天一道LeetCode】#99. Recover Binary Search Tree

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Two ele ...