Java操作数据库(四,JDBC的工具类封装及测试)

14 篇文章 1 订阅
5 篇文章 1 订阅

相信通过对小编前面的文章解析阅读与理解让读者有了一定的内容理解,下面就与小编一起进行更加深入的了解JDBC的工具类吧!

目录

JDBC工具类的封装

为什么要封装工具类?

封装的工具类(在同一个程序没有结束的工具类中,工具类只加载一次!!!)

 为什么工具类中的方法一般都是私有化的(!!!)?

封装驱动(使用配置文件,实现动态获取驱动)

封装数据库操作对象

封装释放资源(其他步骤也可以封装,看自己需要,一般情况封装上面三步骤)

为什么使用Statement不用PreparedStatement 来传入参数?

完整的JDB工具类代码

JDBC工具类的测试


JDBC工具类的封装

为什么要封装工具类?

为了方便后面开发的需要,我们需要封装一个工具类出来。

封装的工具类(在同一个程序没有结束的工具类中,工具类只加载一次!!!

准备工作:在创建的jdbc文件夹下创建一个Utils(名称可以改,但最好有意义)的文件夹,创建一个JdbcUtil的工具类

准备好工具类,下面就可以开始代码的编写了

 为什么工具类中的方法一般都是私有化的(!!!)?

工具类中的方法私有化是为了防止工具类new对象,因为工具类的方法都是静态的,不需要new对象,直接使用类名称.方式调用(如图Arrays工具类一样)。

封装驱动(使用配置文件,实现动态获取驱动)

package com.luosf.jdbc.utils;


import java.sql.*;
import java.util.ResourceBundle;

/**
 * 这个就是Jdbc的工具类
 *
 */
public class JdbcUtil {

    //Suppresses default constructor, ensuring non-instantiability.
    //抑制默认构造函数,确保非实例化性。
    private  JdbcUtil(){

    }

    //使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
    //使用静态变量来实现动态注册驱动
    private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");


    //使用静态代码块:“保证注册驱动在类加载时执行,并且只执行一次”
    //注册驱动
    static{
        try {
            Class.forName(bundle.getString("driver"));
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

}

封装数据库操作对象

package com.luosf.jdbc.utils;


import java.sql.*;
import java.util.ResourceBundle;

/**
 * 这个就是Jdbc的工具类
 *
 */
public class JdbcUtil {

    //Suppresses default constructor, ensuring non-instantiability.
    //抑制默认构造函数,确保非实例化性。
    private  JdbcUtil(){

    }

    //使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
    //使用静态变量来实现动态注册驱动
    private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");


   

    //获取数据库链接对象,返回新的链接对象(一般情况下,外面有错误接受,所有直接抛出错误)
    public static Connection getConnection() throws SQLException {
        //从配置文件中获取需要的内容
        String url = bundle.getString("url");
        String user = bundle.getString("user");
        String password = bundle.getString("password");

        //获取数据库操作对象
        Connection conn = DriverManager.getConnection(url,user,password);

        //返回数据库操作对象
        return conn;
    }

}

封装释放资源(其他步骤也可以封装,看自己需要,一般情况封装上面三步骤)

package com.luosf.jdbc.utils;


import java.sql.*;
import java.util.ResourceBundle;

/**
 * 这个就是Jdbc的工具类
 *
 */
public class JdbcUtil {

    //Suppresses default constructor, ensuring non-instantiability.
    //抑制默认构造函数,确保非实例化性。
    private  JdbcUtil(){

    }


    //释放资源
    //当不需要处理查询结果集是可以这样输入close(conn, stat, null)
    public  static void close(Connection conn, Statement stat, ResultSet res){
        if (res != null){
            try {
                res.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (stat != null){
            try {
                stat.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (conn != null){
            try {
                conn.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }


}

为什么使用Statement不用PreparedStatement 来传入参数?

因为PreparedStatement是 Statement的子类,根据类的三大特性之一的多态性。多态性:同一个行为具有多个不同表现形式或形态的能力。所有使用Statement的能接受PreparedStatement的引用,反之,则不行。

完整的JDB工具类代码

package com.luosf.jdbc.utils;


import java.sql.*;
import java.util.ResourceBundle;

/**
 * 这个就是Jdbc的工具类
 *
 */
public class JdbcUtil {

    //Suppresses default constructor, ensuring non-instantiability.
    //抑制默认构造函数,确保非实例化性。
    private  JdbcUtil(){

    }

    //使用静态变量,在类加载的时候执行,并且要在要在静态代码块前面(因为静态代码块要用)
    //使用静态变量来实现动态注册驱动
    private static ResourceBundle bundle = ResourceBundle.getBundle("resources/db");


    //使用静态代码块:“保证注册驱动在类加载时执行,并且只执行一次”
    //注册驱动
    static{
        try {
            Class.forName(bundle.getString("driver"));
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    //获取数据库链接对象,返回新的链接对象(一般情况下,外面有错误接受,所有直接抛出错误)
    public static Connection getConnection() throws SQLException {
        //从配置文件中获取需要的内容
        String url = bundle.getString("url");
        String user = bundle.getString("user");
        String password = bundle.getString("password");

        //获取数据库操作对象
        Connection conn = DriverManager.getConnection(url,user,password);

        //返回数据库操作对象
        return conn;
    }

    //释放资源
    //当不需要处理查询结果集是可以这样输入close(conn, stat, null)
    public  static void close(Connection conn, Statement stat, ResultSet res){
        if (res != null){
            try {
                res.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (stat != null){
            try {
                stat.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if (conn != null){
            try {
                conn.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }


}

JDBC工具类的测试

竟然工具类已经封装好了下面就可以开始,使用并测试代码是否能正常运行吧!

package com.luosf.jdbc;

import com.luosf.jdbc.utils.JdbcUtil;

import java.sql.*;

/**
 * JDBC工具类的测试类
 */

public class JdbcUtilTest {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement stat = null;
        ResultSet res = null;
        try {
            //1,类加载时就已经注册驱动

            //2,获取链接
            conn = JdbcUtil.getConnection();

            //sql指令
            String sql = "select * from  t_shuihuo where id < ? ";

            //3,sql语句进行编译
            stat = conn.prepareStatement(sql);

            //给占位符填充值
            //JDBC下标从1开始的
            stat.setInt(1,16); //1,代表第一个问号
            
            System.out.println(sql);
            //4,执行sql
            res = stat.executeQuery();

            //5,处理查询结果集
            while (res.next()){
                int id = res.getInt("id");
                String name = res.getString("name");
                String nickname = res.getString("nickname");
                System.out.println("id :"+ id + "  name :" +name + "  昵称 :"+nickname);
            }

        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }finally {
            //6,释放资源
            JdbcUtil.close(conn,stat,res);
            //当没有查询结果集时,传入null
            // JdbcUtil.close(conn,stat,null);
        }
    }
}

 

  • 11
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

韶光不负

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值