数据库连接池
数据库连接池 相当于用这个工具 去管理对数据库的连接和关闭操作 提供datasource数据源给其他组件提供连接数据。
为什么要用数据库连接池:
之前的操作是 程序运行过程中 每当要有增删改查时 就需要单独建立一次对数据库的连接 当操作完成时又断开连接。这样做会导致资源消耗较大 申请连接也比较耗时。操作冗余。
概念:
其实就是一个容器(集合) , 存放数据库连接的容器 一个个connection对象。当系统初始化好后 容器被创建 容器中会申请一些连接对象 当用户来访问数据库时从容器中获取连接对象 用户访问完以后 会将连接对象归还给容器 不会直接释放 可以重复使用 利用率更高。好处:节约资源用户访问高效
实现:
1. 标准接口:DataSource javax.sql 包下1. 方法:* 获取连接: getConnection()* 归还连接:如果连接对象 connection 是从连接池获取的 那么调用Connection.close()方法,则不会关闭连接了 而是归还连接。2. 一般我们不去实现它 由数据厂商实现1. c3p0技术: 数据库连接池技术。2. Druid: 数据库连接池实现技术 由阿里巴巴提供c3p0:数据库连接池技术* 步骤 导入jar包 2个推荐使用配置文件的形式使用 更灵活需要定义名称为 c3p0.properties 或 c3p0-config.xml路径:直接将文件放在src目录下即可创建核心对象 数据库连接池对象 ComboPooledDataSource获取连接: getConnection
代码:
DataSource ds = new ComboPooledDataSource();Connection conn = ds.getConnection();// 这样就可以获取连接 后面操作就和之前jdbc一样了c3p0的配置文件 可以编写多个数据库连接配置 从不同的数据源获取数据 只需要在ComboPooledDataSource();中添加配置名词就可以了。
Druid:
数据库连接池实现技术 由阿里巴巴提供的* 步骤1.导入jar包2.定义配置文件:* 特点1.是properities形式的(key-value形式)2.可以叫任意名称 可以放在任意目录下3.获取数据库连接池对象:通过一个工厂类来获取 DruidDataSourceFactory 获取数据库连接池对象4.获取连接 getConnection()5.演示:Properties pro = new Properties();InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream(\"druid.properties\");pro.load(is);DataSource ds = DruidDataSourceFactory.createDataSource(pro);Connection conn = ds.getConnection();
定义工具类:
1.提供方法:1.获取连接方法:通过数据库连接池获取连接2.释放资源3.获取连接池的方法2.代码```// DruidUtilspackage com.druid.demo;import java.io.IOException;import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Properties;import javax.sql.DataSource;import com.alibaba.druid.pool.DruidDataSourceFactory;public class DruidUtils {//1.定义成员变量 DataSourceprivate static DataSource ds;static {//1. 加载配置文件Properties properties = new Properties();try {properties.load(DruidUtils.class.getClassLoader().getResourceAsStream(\"druid.properties\"));ds = DruidDataSourceFactory.createDataSource(properties);} catch (IOException e) {e.printStackTrace();} catch (Exception e) {e.printStackTrace();}}public static Connection getConnection() throws SQLException {return ds.getConnection();}public static void close(ResultSet rs,Statement stmt,Connection conn) {if( rs != null ) {try {rs.close();} catch (SQLException e) {e.printStackTrace();}}if( stmt != null ) {try {stmt.close();} catch (SQLException e) {e.printStackTrace();}}if(conn!=null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}}}public static void close(Statement stmt,Connection conn) {close(null, stmt, conn);}public static DataSource getDataSourve() {return ds;}}```
主函数