使用配置文件的方式构建数据库连接工具类范例(DBCP)

dbcp.propertise内容:

dirver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://数据库地址:3306/jdbctest
username=root
password=数据库密码
InitialSize=3
MaxTotal=5
MaxWaitMillis=3000

DBCPUtil.java

复制代码
package dbcptest;
/**
 * 数据库连接工具类,每次调用会返回数据库连接对象
 * 使用配置文件的方式方便更改数据库配置信息
 *
 * Title: DBCPUtil
 *
 * Description: 
 *
 * @author Ethan
 *
 * @date 2019年6月23日
 *
 */

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.util.Properties;

import org.apache.commons.dbcp2.BasicDataSource;

public class DBCPUtil {
    
    private static BasicDataSource bds;
    static {
        //创建数据源对象
        bds = new BasicDataSource();
        //读取配置文件
        Properties prop = new Properties();
        InputStream ips = DBCPUtil.class.getClassLoader().getResourceAsStream("dbcp.properties");
        try {
            prop.load(ips);
            
            String driver = prop.getProperty("driver");
            String url = prop.getProperty("url");
            String username = prop.getProperty("username");
            String password = prop.getProperty("password");
            String initialSize = prop.getProperty("InitialSize");
            String maxTotal = prop.getProperty("MaxTotal");
            String maxWaitMillis = prop.getProperty("MaxWaitMillis");
            
            //配置连接信息
            bds.setDriverClassName(driver);
            bds.setUrl(url);
            bds.setUsername(username);
            bds.setPassword(password);
            bds.setInitialSize(Integer.valueOf(initialSize));
            bds.setMaxTotal(Integer.valueOf(maxTotal));
            bds.setMaxWaitMillis(Integer.valueOf(maxWaitMillis));
        } catch (IOException e) {
            e.printStackTrace();
        }
        
    }
    
    public static Connection getConn() throws Exception {
        Connection conn = bds.getConnection();
        System.out.println("conn");
        return conn;
    }
}
复制代码

 

posted @   WaterGe  阅读(359)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
点击右上角即可分享
微信分享提示