JDBC: 简化JDBC语句,封装DBUtil简单库

(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

你可能感兴趣的:(#,JDBC)