博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jdbc 链接池
阅读量:6682 次
发布时间:2019-06-25

本文共 2688 字,大约阅读时间需要 8 分钟。

package cn.itcast.jdbc.datasourse;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.LinkedList;
public class MyDataSourse {
    private static String url = "jdbc:mysql://localhost:3306/test";
    private static String user = "root";
    private static String pwd = "";
    
    //用于存放链接
    private LinkedList<Connection> connectionsPool = new LinkedList<Connection>();
    
    //初始化链接池时,向链接池内放入10个链接   
    public MyDataSourse(){
        try {
            for(int i = 0;i< 10 ;i++){
                this.connectionsPool.addLast(this.createConnection());
            }
        } catch (SQLException e) {
//            e.printStackTrace();
            throw new ExceptionInInitializerError(e);
        }
    }
    //得到链接
    public Connection getConnection(){
        return this.connectionsPool.removeFirst();
    }
    
    //释放链接  如果用链接池的话,当我们要释放资源的时候就不能够简单的把conn给关闭掉,而应该是把conn重新放回到链接池中
    public void free(Connection conn){
        this.connectionsPool.addLast(conn);
    }
    //创建链接
    private Connection createConnection() throws SQLException{
        return DriverManager.getConnection(url,user,pwd);
    }
}
/*
 * 当我们对数据库进行操作时,往往花费在建立和数据库的链接时花费的时间最长,所以最好就是链接保证链接不要
 * 频繁的建立,这时就应该考虑到创建一个链接池,每次用的时候直接从链接池中去取,用完后再放回去
 * 这样做虽然在创建时花费的时间会很长,但是一旦创建完成,在用的时候就能够很好的提高效率
 * */
//此时jdbcUtils包就应该改为这样//

package cn.itcast.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import cn.itcast.jdbc.datasourse.MyDataSourse;
public final class JdbcUtils {
    private static String url = "jdbc:mysql://localhost:3306/test";
    private static String user = "root";
    private static String password = "";
   // private static MyDataSourse myDataSourse = new MyDataSourse();    //这里myDataSourse不能在这里进行初始化,因为myDataSourse的初始化动作之前需要先注册驱动

  private static MyDataSourse myDataSourse = null;  //此处只需要声明一下,初始化动作放在注册驱动的后面,不然会报初始化异常

    // 私有的构造方法
    private JdbcUtils() {
    }
    // 把注册驱动的动作放在静态代码块内
    static {
        try {
            Class.forName("com.mysql.jdbc.Driver");

    myDataSourse = new MyDataSourse();    //初始化动作放在注册驱动的后面

        } catch (ClassNotFoundException e) {
            e.printStackTrace();
            throw new ExceptionInInitializerError(e);
        }
    }
    // 建立链接
    public static Connection getConnection() throws SQLException {
//        return DriverManager.getConnection(url, user, password);
        return myDataSourse.getConnection();
    }
    // 释放资源
    public static void free(ResultSet rs, Statement st, Connection conn) {
        try {
            if (rs != null) {
                rs.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (st != null) {
                    st.close();
                }
            } catch (SQLException e) {
                e.printStackTrace();
            } finally {
                try {
                    if (conn != null) {
                        //conn.close(); 当使用链接池时,此处就不能够简单的关闭掉该conn了
                        myDataSourse.free(conn);//此时应该把链接conn重新放回到链接池中
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

转载于:https://www.cnblogs.com/siashan/p/3881225.html

你可能感兴趣的文章
Linux系统的启动和修复模式
查看>>
Citrix ICA协议简要介绍
查看>>
软件发布版本区别介绍
查看>>
python操作selenium的基本操作
查看>>
kvm虚拟机迁移
查看>>
Docker 修改docker容器内部时间
查看>>
解决windows下redis狂占C盘内存
查看>>
yii2高级模板添加新增模块
查看>>
【推荐】(SqlServer)不公开存储过程sp_Msforeachtable与sp_Msforeachdb详解
查看>>
在结构体内定义宏
查看>>
TURBOGATE邮件网关——最经济高效的企业网关选择
查看>>
MS14-058 最新提权神器
查看>>
数据挖掘算法(Analysis Services – 数据挖掘)
查看>>
Apache配置详解(最好的APACHE配置教程)
查看>>
JAVA笔记——String类
查看>>
我的友情链接
查看>>
CentOS 7 下基于基 bitnami 安装部署 redmine
查看>>
DEDE 标签汇总
查看>>
华章1-2月份新书简介(2019年)
查看>>
我的友情链接
查看>>