DataSource 与 连接池的源码基础---原理讲解

学完JDBC技术之后,对connections数量的控制有所学习,本文主要了解了数据连接池的工作原理。图一:synchronized void createPool()和Connection getConnection()方法,分别实现了连接池的创建和物理连接的创建。图二:介绍了returnConnection()、refreshConnection()、closeConn
摘要由CSDN通过智能技术生成

学完JDBC技术之后,对connections数量的控制有所学习,本文主要了解了数据连接池的工作原理。

图一

synchronized void createPool()和Connection getConnection()方法,

分别实现了连接池的创建和物理连接的创建。



图二:

介绍了returnConnection()、refreshConnection()、closeConnection()、CloseConnectionPool()工作原理。暂时本人还未清楚到底作为连接池,是否需要closeConnection()。




源代码如下:

//
//    一个效果非常不错的JAVA数据库连接池.
//    from:http://www.jxer.com/home/?uid-195-action-viewspace-itemid-332
//    虽然现在用APACHE COMMONS DBCP可以非常方便的建立数据库连接池,
//    但是像这篇文章把数据库连接池的内部原理写的这么透彻,注视这么完整,
//    真是非常难得,让开发人员可以更深层次的理解数据库连接池,真是非常感
//    谢这篇文章的作者。
//
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Enumeration;
import java.util.Vector;


public class ConnectionPool {

    private String jdbcDriver = ""; // 数据库驱动
    private String dbUrl = ""; // 数据 URL
    private String dbUsername = ""; // 数据库用户名
    private String dbPassword = ""; // 数据库用户密码
    private String testTable = ""; // 测试连接是否可用的测试表名,默认没有测试表
    private int initialConnections = 10; // 连接池的初始大小
    private int incrementalConnections = 5; // 连接池自动增加的大小
    private int maxConnections = 50; // 连接池最大的大小
    private Vector
   
   
    
     connections = null; // 存放连接池中数据库连接的向量 , 初始时为 null
// 它中存放的对象为 PooledConnection 型

   
    public ConnectionPool(String jdbcDriver, String dbUrl, String dbUsername,
                          String dbPassword) {

        this.jdbcDriver = jdbcDriver;
        this.dbUrl = dbUrl;
        this.dbUsername = dbUsername;
        this.dbPassword = dbPas
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值