IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Java操作数据库(四,JDBC的工具类封装及测试) -> 正文阅读

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

相信通过对小编前面的文章解析阅读与理解让读者有了一定的内容理解,下面就与小编一起进行更加深入的了解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);
        }
    }
}

?

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-12-13 12:40:04  更:2021-12-13 12:40:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 5:19:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码