(1)为了简化JDBC编程六步,封装一个DBUti库,以后直接调用。
这个程序用到了静态代码块:在类加载时执行,且只执行一次
package com.jdbc.utils;
import java.sql.*;
/**
* JDBC工具类,简化JDBC编程
* 封装库
* */
public class DBUtil {
/**
* 工具类中的构造方法都是私有的。
* 因为工具类当中的方法都是静态的,不需要new对象,直接采用类名调用。
* */
private DBUtil () {
}
//静态代码块在类加载时执行,且只执行一次
static{
try{
Class.forName("com.mysql.cj.jdbc.Driver");
}catch(Exception e){
e.printStackTrace();
}
}
/**
* 获取数据库操作对象
* @return 连接对象
* @throws Exception
* */
public static Connection getConnection() throws Exception{
return DriverManager.getConnection("jdbc:mysql://localhost:3306/bjpowernode?serverTimezone=GMT%2B8","root","jh7851192");
}
/**
* 关闭资源
* @param conn 连接对象
* @param ps 数据库操作对象
* @param rs 查询结果集
* */
public static void close (Connection conn, PreparedStatement ps, ResultSet rs){
if(rs != null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(ps != null){
try {
ps.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(conn != null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
(2)测试DBUtil是否好用和模糊查询怎么写 like
package com.jdbc;
import com.jdbc.utils.DBUtil;//导包
import java.sql.*;
/**
* 这个程序测试两个任务:
* --第一:测试DBUtil是否好用
* --第二:模糊查询怎么写 like
* */
public class JDBCTest11 {
public static void main(String[] args) {
Connection conn=null;
PreparedStatement ps =null;
ResultSet rs=null;
/**DBUtil类去调用getConnection()方法时,会类加载,这样
* DBUtil类中的静态代码块只会执行一次,就会注册驱动
*/
try {
//获取连接
conn= DBUtil.getConnection();
//获取预编译的数据库操作对象
String sql="select ename from emp1 where ename like ?";
ps=conn.prepareStatement(sql);
ps.setString(1,"_A%");
rs=ps.executeQuery();
while(rs.next()){
System.out.println(rs.getString("ename"));
}
} catch (Exception e) {
e.printStackTrace();
}finally {
//释放资源
DBUtil.close(conn,ps,rs);
}
}
}
结果:
WARD
MARTIN
JAMES
WARD
MARTIN
JAMES