zoukankan      html  css  js  c++  java
  • 数据库连接池 c3p0 demo 代码和分析

    import java.sql.Connection;
    import java.sql.SQLException;
    import java.beans.PropertyVetoException;
    import com.mchange.v2.c3p0.ComboPooledDataSource;
    
    public class Dafa {
        private static DBPool dbPool;
        private ComboPooledDataSource dataSource;
    
        static {
            dbPool = new DBPool();
        }
    
        public Dafa() {
            try {
                dataSource = new ComboPooledDataSource();
                dataSource.setUser("id ");
                dataSource.setPassword("pw ");
                dataSource.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=GB2312 ");
                dataSource.setDriverClass("com.mysql.jdbc.Driver ");
                dataSource.setInitialPoolSize(2);
                dataSource.setMinPoolSize(1);
                dataSource.setMaxPoolSize(10);
                dataSource.setMaxStatements(50);
                dataSource.setMaxIdleTime(60);
            } catch (PropertyVetoException e) {
                throw new RuntimeException(e);
            }
        }
    
        public final static DBPool getInstance() {
            return dbPool;
        }
    
        public final Connection getConnection() {
            try {
                return dataSource.getConnection();
            } catch (SQLException e) {
                throw new RuntimeException("无法从数据源获取连接 ", e);
            }
        }
    
        public static void main(String[] args) throws SQLException {
            Connection con = null;
            try {
                con = DBPool.getInstance().getConnection();
            } catch (Exception e) {
            } finally {
                if (con != null)
                    con.close();
            }
        }
    
    }

    使用连接池的时候并不是在代码中不用获取/释放数据库连接,而是在代码中向连接池申请/释放连接,对于代码而言,可以把连接池看成数据库。

    换句话说,连接池就是数据库的代理,之所以要使用这个代理是因为直接向数据库申请/释放连接是要降低性能的:如果每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,那么频繁发生这种数据库操作时,系统的性能必然会急剧下降。

    连接池的作用是自己维护数据库连接,数据库连接池的主要操作如下:
      (1)建立数据库连接池对象(服务器启动)。
      (2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。
      (3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。
      (4)存取数据库。
      (5)关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。
      (6)释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。

    转自:http://hi.baidu.com/zjq588/item/df2aa4c899024711505058ff

  • 相关阅读:
    记通过身份证号计算是否成年
    mysql出现which is not functionally dependent on columns in GROUP BY clause报错
    Git操作之 git add 撤销、git commit 撤销
    laraval ueditor 上传图片失败
    jquery调用百度api连接实现网页实时刷新汇率
    Laravel框架使用maatwebsite/excel 导出表格样式自定义
    数字千分位格式化
    laravel 5.4 解决使用Excel::load()导入的excel文件中日期格式变为数字
    layui select可以使用jQuery的change事件
    Linux系统通过命令修改BT宝塔面板的默认8888端口
  • 原文地址:https://www.cnblogs.com/olmlo/p/3633322.html
Copyright © 2011-2022 走看看