何时本身建立工具类
- 若是一个功能常常要用到, 咱们建议把这个功能作成一个工具类, 能够在不一样的地方重用
- 得到数据库链接操做,将在之后的增删改查全部功能中都存在.因此能够封装工具类
JDBCUtils
,提供获取链接对象的方法, 从而达到代码重复利用
JDBC工具类包含的内容
- 自定义成员常量: 用户名,密码,URL,驱动类
- 自定义成员方法
getConnection()
获取链接
- 关闭全部打开的资源
JDBCUtils示例代码
public class JDBCUtils {
private static final String DATABASE = "lianxi01";
private static final String USER = "root";
private static final String PASSWORD = "316426";
private static final String URL = "jdbc:mysql://localhost:3306/" + DATABASE + "?characterEncoding=UTF-8&useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";
private static Connection conn = null;
private static Statement sqlExecute = null;
// a. 获取链接
public static Connection getConnection(){
try {
// 1. 注册驱动
Class.forName("com.mysql.cj.jdbc.Driver");
// 2. 链接数据库
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
return conn;
}
// b. 获取语句执行平台 Statement对象
public static Statement createStatement(Connection conn){
// 3. 获取语句执行平台
try {
sqlExecute = conn.createStatement();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
return sqlExecute;
}
// 3. 关闭流对象 --- 未执行查询语句
public static void close(Connection conn, Statement sqlExecute){
try {
if(null != sqlExecute) {
sqlExecute.close();
}
if(null != conn) {
conn.close();
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
// 关闭流对象 --- 执行查询语句 方法重载
public static void close(Connection conn, Statement sqlExecute, ResultSet resultset){
try {
if(null != resultset) {
resultset.close();
}
if(null != sqlExecute) {
sqlExecute.close();
}
if(null != conn) {
conn.close();
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}