一. 使用数据库连接池有什么优势
在程序开发的过程中如果不使用数据库连接池 , 可能会导致我们每执行一次sql语句 , 就会向数据库发送请求链接与断开 , 这会消耗我们的内存资源
1. 资源重用更佳
- 减少开销:数据库连接池通过复用现有的数据库连接,显著减少了频繁创建和关闭连接所带来的开销。在传统的数据库访问模式中,每次数据库操作都需要建立和关闭连接,这是一个耗时且资源密集型的操作。而连接池通过维护一组持久的连接,使得这些开销被分摊到多个数据库操作上,从而提高了资源利用效率。
- 减少内存碎片:由于减少了连接的频繁创建和销毁,数据库连接池还减少了内存碎片的产生,有助于维护系统内存的健康状态。
2. 系统响应更快
- 预分配连接:数据库连接池在应用初始化的过程中会预先创建一定数量的数据库连接,当业务请求到来时,可以直接使用这些已经建立的连接,而无需等待新连接的创建。这大大缩短了系统响应时间,提高了用户体验。
- 减少等待时间:在高并发场景下,连接池能够更有效地管理连接资源,避免因为等待创建新连接而导致的延迟。
3. 连接管理更灵活
- 配置灵活:数据库连接池允许用户根据实际需求配置连接池的参数,如最小连接数、最大连接数、最大空闲时间、连接超时时间等。这种灵活性使得连接池能够适应不同的应用场景和负载情况。
- 统一管理:连接池作为中间件,提供了统一的连接管理接口,使得应用程序能够更加方便地管理和使用数据库连接。
4. 提高系统稳定性
- 避免连接泄漏:连接池通过监控和管理连接的使用情况,可以有效地避免连接泄漏问题的发生。连接泄漏是指应用程序在使用完数据库连接后没有正确关闭连接,导致连接无法被重新利用,进而造成资源浪费和系统性能下降。
- 减少数据库负载:通过减少频繁创建和关闭连接的操作,连接池还可以降低对数据库服务器的负载,提高系统的整体稳定性和可靠性。
二. 什么是数据库连接池
数据库连接池是connection对象的缓冲区,里面预先存放了一定数量的数据库连接(connection)。当Java程序需要访问数据库时,如果连接池中有可用的连接,则直接从连接池中获取,而无需重新创建新的连接。这种机制使得数据库连接的复用成为可能,从而提高了数据库操作的效率。
三. Druid连接池
Druid是阿里巴巴开发的号称为监控而生的数据库连接池(可以监控访问数据库的性能),Druid是目前最好的数据库连接池。
Druid常用的配置参数
使用方法
-
项目下新建一个druid配置文件,命名为:druid.properties , 写入相关参数
url=jdbc:mysql://localhost:3306/day05_db username=root password=123 driverClassName=com.mysql.jdbc.Driver
-
创建properties对象
Properties properties = new Properties(); properties.load(new FileInputStream("src/druid.properties"));
-
创建数据池连接对象
// 创建数据库链接池对象 DruidDataSourceFactory factory = new DruidDataSourceFactory(); DataSource dataSource = factory.createDataSource(properties);
-
获取数据库链接对象编写sql语句进行操作
Connection connection = dataSource.getConnection(); PreparedStatement statement = connection.prepareStatement("select * from orders"); ResultSet resultSet = statement.executeQuery(); while (resultSet.next()){ System.out.println(resultSet.getString("product")); }
-
输出结果