java数据库连接池笔记

(课程笔记来源于跟着老师敲,老师是黑马程序 b 站白嫖课程 ~)

#数据库连接池:

1、概念:就是一个容器(集合),存放数据连接的容器

      当容器初始化好后,容器会被创建,容器中会申请一些连接对象,当用户来访问数据库是,从容器中获取连接对象,用户访问结束之后,会将连接对象放回到容器中。

2、好处:

  * 节约资源

  * 用户访问高效

3、实现:

  1、接口:DataSourse javax.sql 包下

    1、方法:

      * 获取连接:getConnection()

      * 归还连接:如果连接对象 Connection 是从连接池中获取的,那么调用 Connection.close() 方法,则不会再关闭连接了,而是归还连接

    2、一般我们不去实现,而是由数据库厂商来实现

      1、c3p0(比较老的数据库连接池技术

      2、Druid:阿里提供的数据库连接池技术

4、c3p0

  步骤:

    1、导入 jar 包 c3p0-0.9.5.2   mchange-commons-java-0.2.12 

    2、定义配置文件:

    * 名称:c3p0.properties 或者 c3p0-config.xml

    * 路径:直接将文件放在 src 目录下即可。

    3、创建核心对象 数据库连接池对象 ComboPoolDataSource

    4、获取连接:getConnection

 

demo:

 1 package cn.it.c3p0;
 2 
 3 import com.mchange.v2.c3p0.ComboPooledDataSource;
 4 import com.mchange.v2.c3p0.DataSources;
 5 
 6 import javax.sql.DataSource;
 7 import java.sql.Connection;
 8 import java.sql.SQLException;
 9 
10 //c3p0demo
11 public class c3p0_demo {
12     public static void main(String[] args) throws SQLException {
13         //1 creat
14         DataSource ds = new ComboPooledDataSource();
15         //get
16         Connection conn = ds.getConnection();
17         //pr
18         System.out.println(conn);
19     }
20 }

运行时报错了

 

 

看了弹幕才知道 自己用错了方法,这个 DataSource 不是用 c3p0 包里的

而是用 java 自带的才可以 ~!!!

    改正后打印日志信息 finish~~

5、Druid:
* 步骤:

  1、导入 jar 包 druid-1.0.9.jar

  2、定义配置文件:

    * 是 properties 形式的

    * 可以叫任意名称,可以放在任意目录下,而 c3p0 是名称定的情况下,系统会自动访问

  +:加载配置文件 properties

  3、获取数据库连接池对象:通过工厂来获取 DruidDataSourceFactory

  4、获取连接:getConnection

package cn.it.Duird;

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.naming.spi.DirStateFactory;
import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.util.Properties;

public class DiudDemo {
public static void main(String[] args) throws Exception {
//加载配置文件
Properties pro = new Properties();
InputStream is
= DiudDemo.class.getClassLoader().getResourceAsStream("druid.properties");
pro.load(is);
//获取连接池对象
DataSource ds = DruidDataSourceFactory.createDataSource(pro);
//获取连接
Connection conn = ds.getConnection();
System.out.println(conn);
}
}

 2、定义工具类

  1、 定义一个工具类 JDBCUtils

  2、提供静态代码块加载配置文件,初始化连接池对象

  3、提供方法

    1、获取连接方法:通过数据库连接池获取连接

    2、释放资源

    3、获取连接池方法

 

JDBCUtils
Demo

如果需要 jar 包 还有什么安装包啥的 dd 我 我找找发一下 ~~ 嘿嘿!相互学习