数据库连接池(Druid, dbcp, c3p0)

  • 数据库连接池的基本思想,是在系统初始化时将数据库连接作为对象存储在内存中
  • 当需要用到数据库连接时,从池中取出连接而非新建,使用完后放回池中而非立刻关闭
  • 连接的建立、关闭由连接池管理,可以通过连接池自身的管理机制来监视数据库连接的数量、使用情况等。
  • 数据库连接池的一些参数:
    • 初始连接数
    • 连接数的上下限
    • 连接的最大使用次数
    • 最大空闲时间

自定义连接池

自定义数据库连接池应该具备的基本属性和方法

import java.sql.Connection;
import java.sql.SQLException;
import java.util.LinkedList;


public class MyPool {
   

    static LinkedList<Connection> pool = new LinkedList<>();
    static {
   
        for (int i = 0; i < 10; i++) {
   
            Connection connection = new JDCBUtils.newInstance().getConnection();
            pool.add(connection);
        }
    }

    /**
     * 从池子中取出连接
     * @return
     */
    public Connection getConnection(){
   
        if (pool.isEmpty()) {
   
            Connection connection = new JDCBUtils.newInstance().getConnection();
            pool.add(connection);
        }
        Connection connection = pool.removeFirst();

        return connection;
    }

    /**
     * 将连接保存到池子里
     * @param connection
     */
    public void addBack(Connection connection){
   
        if (pool.size() > 10) {
   
            try {
   
                connection.close();
            } catch (SQLException e) {
   
                e.printStackTrace();
            }
        } else {
   
            pool.addLast(connection);
        }
    }

    /**
     * 返回连接池的数量
     * @return
     */
    public int getSize(){
   
        return pool.size();
    }

    /**
     *其它方法
     */
}

Java规范实现连接池

需要用到DataSource接口,但DateSource接口没有提供回收连接的方法,对Connection接口进行装饰,重写里面的close方法可以解决该问题

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.LinkedList;

public class MyConnection implements Connection {
   
    private Connection connection;
    private LinkedList<Connection> pool;

    public MyConnecti
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值