2021/6/29 今天写一个工具类
package demo29JDBC;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.net.URL;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
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 {
Properties pro = new Properties();
// 获取src路径下的文件的方式-->classloader类加载器
ClassLoader classLoader = JDBCUtils.class.getClassLoader();
URL res = ClassLoader.getSystemResource("jdbc.properties");
System.out.println(res);
String path = res.getPath();
pro.load(new FileReader(path));
// 获取属性赋值
url = pro.getProperty("url");
user = pro.getProperty("user");
password = pro.getProperty("password");
driver = pro.getProperty("driver");
// 注册驱动
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static Connection getConnection() throws Exception {
/*获取链接,文件读取使用静态代码块*/
return DriverManager.getConnection(url, user, password);
}
public static void close(ResultSet rs, Statement stmt, Connection conn) {
// 释放资源
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if (stmt != null) {
try {
stmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
public static void main(String[] args) {
try {
Connection conn = JDBCUtils.getConnection();
System.out.println(conn);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
反复出现无法读取到properties的问题,最后发现是因为工作空间workspace second 中间有一个空格!!!!!!