[JavaWeb学习]数据库连接池

数据库连接池概述

数据库连接池是一个容器,负责分配、管理数据库连接(Connection)

它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个

释放空闲事件超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏(当用户长时间占用Connection,但是不进行操作的时候,此时数据库连接池就会强行释放连接)
[JavaWeb学习]数据库连接池_第1张图片

数据库连接池实现

标准接口:DataSource
SUN提供的数据库连接池标准接口,又第三方组织实现此功能

常见数据库连接池:DBCP、C3P0、Druid(阿里开源的,下面就用这个)

1、导入jar包 druid-1.1.12.jar(也要记得sava as library)

2、

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///db1?useSSL=false&useServerPrepStmts=true
username=root
password=1234
#初始化连接数量
initialSize=5
#最大连接数
maxActive=10
#最大等待时间  
maxWait=3000   #3000毫秒

写到src目录下

3、

package henu;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.FileInputStream;
import java.sql.Connection;
import java.util.Properties;

public class JDBCdruid {
    public static void main(String[] args) throws Exception {
        //1、导入jar包

        //2、定义配置文件

        //3、加载配置文件


        Properties prop=new Properties();
        prop.load(new FileInputStream("src/druid.properties"));


        //4、获取连接池对象
        DataSource dataSource = DruidDataSourceFactory.createDataSource(prop);

        //5、获取数据库连接Connection
        Connection connection = dataSource.getConnection();

        System.out.println(connection);

        //后面写的代码就是一样的了
        
    }
}

System.out.println(System.getProperty("user.dir"));
打印当前所在路径!!!
当定位不到druid.properties,可以看当前所在位置

你可能感兴趣的:(JavaWeb,javaweb)