*抽取 目的:简化书写
* 分析:
1. 注册驱动也抽取
2. 抽取一个方法获取连接对象
* 需求:不想传递参数(麻烦),还得保证工具类的通用性。
* 解决:配置文件
jdbc.properties
url=jdbc:mysql://IP地址:端口号/数据库名
user=root(MySQL用户默认都是root)
password=110505(这里需要换用你自己的root用户的密码)
3. 抽取一个方法释放资源
代码实现:
package com.itheima_01.utils;
import java.io.FileReader;
import java.io.IOException;
import java.net.URL;
import java.sql.*;
import java.util.Properties;
public class JDBCUtils {
private static String url;
private static String user;
private static String password;
private static String driver;
static {
//读取资源文件,获取值
try {
//获取src路径下的文件的方式 ----> classLoader:类加载器
ClassLoader classLoader = JDBCUtils.class.getClassLoader();
URL res = classLoader.getResource("jdbc.properties");
String path = res.getPath();
//创建Properties集合对象
Properties prop = new Properties();
//加载文件
prop.load(new FileReader(path));
// System.out.println(path); //获取配置文件路径
//通过键获取值
url = prop.getProperty("url");
user = prop.getProperty("user");
password = prop.getProperty("password");
driver = prop.getProperty("driver");
//加载驱动
Class.forName(driver);
} catch (IOException e) {
e.printStackTrace();
System.out.println(e);
} catch (ClassNotFoundException e) {
e.printStackTrace();
System.out.println(e);
}
}
/**
* 获取连接
*
* @return 连接对象
*/
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(url, user, password);
}
/**
* 关闭DQL(查询语句)资源
* @param rs 释放结果集对象 ResultSet
* @param stmt 释放获取执行sql语句对象 Statement
* @param conn 释放连接对象 Connection
*/
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();
}
}
}
/**
* 关闭DML(增删改语句)资源
* @param stmt 释放执行SQL语句的对象 Statement
* @param conn 释放连接对象 Connection
*/
public static void close(Statement stmt, Connection conn) {
if (stmt != null) {
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}