package cn.kgc.smbms.util;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;
import java.util.logging.Logger;
/**
* 开启关闭JDBC的工具类
*/
public class DBUtil {
static Logger log = Logger.getLogger("DBUtil");
private static final String DRIVER_CLASS_NAME;
private static final String URL;
private static final String USERNAME;
private static final String PASSWORD;
private static Connection conn;
static {
// 数据源配置写在properties配置文件中。
Properties prop = new Properties();
try(InputStream is = DBUtil.class.getClassLoader().getResourceAsStream("db.properties")) {
prop.load(is);
} catch (Exception e) {
e.printStackTrace();
log.info(">>>加载数据源配置失败!>>>");
}
// 对象赋值
DRIVER_CLASS_NAME = prop.getProperty("jdbc.driverClassName");
URL = prop.getProperty("jdbc.url");
USERNAME = prop.getProperty("jdbc.username");
PASSWORD = prop.getProperty("jdbc.password");
}
static {
try {
Class.forName(DRIVER_CLASS_NAME);
} catch (ClassNotFoundException e) {
e.printStackTrace();
log.info(">>>加载驱动失败>>>");
}
}
// 连接数据库
/**
* @return 连接对象
* @throws SQLException
*/
public static Connection getConnection() throws SQLException {
if(conn == null || conn.isClosed()) {
conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
}
return conn;
}
public static void closeResource(ResultSet rs, PreparedStatement ps, Connection conn) {
try {
if(rs != null) {
rs.close();
}
if(ps != null) {
ps.close();
}
if(conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
log.info(">>>关闭资源失败>>>");
}
}
private DBUtil() {
}
}
MySQL-JDBC连接工具类
于 2021-02-20 18:15:05 首次发布