zoukankan      html  css  js  c++  java
  • DBCP连接池

    l  DBCP 是 Apache 软件基金组织下的开源连接池实现,使用DBCP数据源,应用程序应在系统中增加如下两个 jar 文件:

    • Commons-dbcp.jar:连接池的实现
    • Commons-pool.jar:连接池实现的依赖库

    l  Tomcat 的连接池正是采用该连接池来实现的。该数据库连接池既可以与应用服务器整合使用,也可由应用程序独立使用。

    l  核心类:BasicDataSource

    l  使用步骤

    • 引入jar文件
     commons-dbcp-1.4.jar
     commons-pool-1.5.6.jar
    package com.loaderman.demo.c_dbcp;
    
    import java.io.InputStream;
    import java.sql.Connection;
    import java.util.Properties;
    
    import javax.sql.DataSource;
    
    import org.apache.commons.dbcp.BasicDataSource;
    import org.apache.commons.dbcp.BasicDataSourceFactory;
    import org.junit.Test;
    
    public class App_DBCP {
    
        // 1. 硬编码方式实现连接池
        @Test
        public void testDbcp() throws Exception {
            // DBCP连接池核心类
            BasicDataSource dataSouce = new BasicDataSource();
            // 连接池参数配置:初始化连接数、最大连接数 / 连接字符串、驱动、用户、密码
            dataSouce.setUrl("jdbc:mysql:///jdbc_demo");            //数据库连接字符串
            dataSouce.setDriverClassName("com.mysql.jdbc.Driver");  //数据库驱动
            dataSouce.setUsername("root");                            //数据库连接用户
            dataSouce.setPassword("root");                             //数据库连接密码
            dataSouce.setInitialSize(3);  // 初始化连接
            dataSouce.setMaxActive(6);      // 最大连接
            dataSouce.setMaxIdle(3000);   // 最大空闲时间
    
            // 获取连接
            Connection con = dataSouce.getConnection();
            con.prepareStatement("delete from admin where id=3").executeUpdate();
            // 关闭
            con.close();
        }
    
        @Test
        // 2. 【推荐】配置方式实现连接池  ,  便于维护
        public void testProp() throws Exception {
            // 加载prop配置文件
            Properties prop = new Properties();
            // 获取文件流
            InputStream inStream = App_DBCP.class.getResourceAsStream("db.properties");
            // 加载属性配置文件
            prop.load(inStream);
            // 根据prop配置,直接创建数据源对象
            DataSource dataSouce = BasicDataSourceFactory.createDataSource(prop);
    
            // 获取连接
            Connection con = dataSouce.getConnection();
            con.prepareStatement("delete from admin where id=4").executeUpdate();
            // 关闭
            con.close();
        }
    }

    db.propertes配置文件

    url=jdbc:mysql:///jdbc_demo
    driverClassName=com.mysql.jdbc.Driver
    username=root
    password=root
    initialSize=3
    maxActive=6
    maxIdle=3000
  • 相关阅读:
    C#生成指定范围内的不重复随机数
    jquery移除元素某个属性
    让html里的js脚本延迟5秒运行
    jquery刷新局部和全页的方法
    jquery旋转插件rotate参数说明
    按照日期生成编号
    ajax请求成功后如何调用bootstrap modal?
    WPF MVVM模式不用Prism
    C#去掉字符串两端空格以及去掉字符串中多余空格保留一个空格
    依赖项属性
  • 原文地址:https://www.cnblogs.com/loaderman/p/10018725.html
Copyright © 2011-2022 走看看