JDBC工具类,连接数据库,关闭资源的方法,数据库信息保存到.properties文件,使用InputStream读取.properties文件
MySQL
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Properties;
/*
* JDBC工具类 连接数据库 读取数据库信息 关闭资源
*/
public class JDBCUtils {
/*
* 把数据库的信息设为静态变量,全局变量
*/
private static String driverClass;
private static String url;
private static String username;
private static String password;
//数据库连接对象
private static Connection con;
//读取对象
private static InputStream in = null;
//把数据库连接放入静态代码块
static {
try {
//调用读取.properties文件的方法,获得连接数据库的必要信息
readProperties();
Class.forName(driverClass);
con = DriverManager.getConnection(url, username, password);
} catch (Exception e) {
// TODO: handle exception
throw new RuntimeException(e.getStackTrace()+"连接数据库失败");
}finally {
if(in != null) {
try {
in.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
//对外公开的JDBC数据库连接,供开发人员调用,返回connection数据库的连接
public static Connection getConnection() {
return con;
}
//读取.properties文件的方法,数据库信息保存在.properties文件中
public static void readProperties(){
in = JDBCConfig.class.getClassLoader().getResourceAsStream("database.propertise");
Properties pro = new Properties();
try {
pro.load(in);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
driverClass = pro.getProperty("driverClass");
url = pro.getProperty("url");
username = pro.getProperty("username");
password = pro.getProperty("password");
}
//关闭资源 针对查询的资源删除
public static void close
(ResultSet rs , Statement stat , Connection con ) {
if(rs != null) {
try {
rs.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(stat != null) {
try {
stat.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(con != null) {
try {
con.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
//关闭资源 针对增删改的资源关闭
public static void close( Statement stat , Connection con ) {
if(stat != null) {
try {
stat.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(con != null) {
try {
con.close();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
database.propertise文件 中的信息
driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybase
username=root
password=root