欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JDBC連接MySQL并實現(xiàn)模糊查詢

 更新時間:2022年01月04日 08:53:12   作者:九九舅舅酒酒  
本文詳細講解了JDBC連接MySQL并實現(xiàn)模糊查詢的方式,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

場景:

在學習JDBC的語言中,每次都執(zhí)行通用的幾步:即注冊驅動,獲取連接,創(chuàng)建操作,處理結果,釋放資源 過于復雜,因此不妨將上述步驟封裝成工具類,只對外提供方法!

描述:

這是不使用工具類的封裝寫出來的代碼,比較冗余復雜

package com.zdx.JDBC;
 
import java.sql.*;
 
public class JAVA1129_5 {
    public static void main(String[] args) {
        //設置空對象,注冊驅動,獲取連接,創(chuàng)建操作,處理結果集,釋放資源
        String url = "jdbc:mysql://127.0.0.1:3306/hello";
        String username = "root";
        String password = "rota";
 
        String SQL = "insert into stu values(1,'zdx','nbnc'),(2,'cyc','qwq');";
//        String SQL1 = "update stu set sname ='xzq',major='bask' where sno = '1';";
        String SQL1="select * from stu";
        Connection connection = null;
        Statement statement = null;
        ResultSet resultset = null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            connection = DriverManager.getConnection(url, username, password);
            statement = connection.createStatement();
            int cnt = statement.executeUpdate(SQL);
            if (cnt != 0) {
                System.out.println("執(zhí)行成功");
            }
            ResultSet result = statement.executeQuery(SQL1);
            while (result.next()) {
                //隨著光標移動對操作對象進行操作
                System.out.println("nbnb");
            }
 
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
 
        //釋放資源,必須在最后加上finally語句塊執(zhí)行
        finally {
                if (resultset != null) {
                    try {
                        resultset.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
                if (statement != null) {
                    try {
                        statement.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
                if (connection != null) {
                    try {
                        connection.close();
                    } catch (SQLException throwables) {
                        throwables.printStackTrace();
                    }
                }
            }
        }
    }
 
 

解決方案:

首先類內的構造方法加私有修飾符,模仿Sun公司工具類,如Arrays類 和 Collection 。

其次注冊驅動,利用靜態(tài)代碼塊內只注冊一次進行注冊驅動

然后獲取數據庫連接,返回數據庫連接對象的方法內有異常,不能catch,需要向外扔。

最后封裝一個關閉的方法。

注意由于封裝工具類,且對外只提供方法因此都封裝成類方法(即static修飾)

package com.zdx.JDBC;
 
import java.sql.*;
 
//2021.11.2920點03分 對數據庫的工具類進行封裝
public class  DBUtil{
    private DBUtil(){}
    static{
        try {
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }//利用靜態(tài)代碼塊在類加載時只加載一次的特性注冊驅動。
 
    //獲取連接的方法
    public static Connection getConnection (String url,String user,String password)throws SQLException{
       return   DriverManager.getConnection(url,user,password);//這里注意驅動管理類內調用的獲取連接方法返回對象就是connection對象。
    }
 
    //關閉資源
    //按照順序,結果集,數據庫操作對象,連接對象!
    public static void close(Connection connection,Statement ps,ResultSet resultSet){
 
        if(resultSet!=null){
            try {
                resultSet.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
 
        if(ps!=null){
            try {
                ps.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
 
        if(connection!=null){
            try {
                connection.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }
 
}

 對工具類進行調用實現(xiàn)模糊查詢:

package com.zdx.JDBC;
 
import java.sql.*;
 
public class Main {
 
    public static void main(String[] args) {
 
        Connection connection = null;
        PreparedStatement ps = null;
        ResultSet resultSet = null;
        String url = "jdbc:mysql://127.0.0.1:3306/hello";
        String user = "root";
        String password = "rota";
        //獲取連接
        try {
            connection = DBUtil.getConnection(url, user, password);
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        //獲取預編譯的數據庫操作對象
        String SQL = "select sname from stu where sname like ?";
        try {
            ps = connection.prepareStatement(SQL);
            ps.setString(1, "_y%");
            resultSet = ps.executeQuery();
            while (resultSet.next()) {
                System.out.println(resultSet.getString("sname"));
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
 
 
        //釋放資源
        finally {
            DBUtil.close(connection, ps, resultSet);
        }
    }
}

到此這篇關于JDBC連接MySQL并實現(xiàn)模糊查詢的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • RabbitMQ 如何解決消息冪等性的問題

    RabbitMQ 如何解決消息冪等性的問題

    這篇文章主要介紹了RabbitMQ 如何解決消息冪等性的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Spring Boot自定義配置實現(xiàn)IDE自動提示功能

    Spring Boot自定義配置實現(xiàn)IDE自動提示功能

    這篇文章主要介紹了Spring Boot自定義配置實現(xiàn)IDE自動提示功能,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • Java時間處理第三方包Joda?Time使用詳解

    Java時間處理第三方包Joda?Time使用詳解

    這篇文章主要為大家介紹了Java時間處理第三方包Joda?Time使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • @RequestBody的使用案例代碼

    @RequestBody的使用案例代碼

    @RequestBody主要用來接收前端傳遞給后端的json字符串中的數據的,這篇文章主要介紹了@RequestBody的使用,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • 解決pageHelper分頁失效以及如何配置問題

    解決pageHelper分頁失效以及如何配置問題

    這篇文章主要介紹了解決pageHelper分頁失效以及如何配置問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 完全解析Java編程中finally語句的執(zhí)行原理

    完全解析Java編程中finally語句的執(zhí)行原理

    這篇文章主要深度介紹了Java編程中finally語句的執(zhí)行原理,細致講解了finally在異常處理中的流程控制作用,需要的朋友可以參考下
    2015-11-11
  • Java Swing JSlider滑塊的實現(xiàn)示例

    Java Swing JSlider滑塊的實現(xiàn)示例

    這篇文章主要介紹了Java Swing JSlider滑塊的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • 小白也可以學會的Java NIO的Write事件

    小白也可以學會的Java NIO的Write事件

    剛開始對NIO的寫操作理解的不深,不知道為什么要注冊寫事件,何時注冊寫事件,為什么寫完之后要取消注冊寫事件,今天特地整理了本篇文章,需要的朋友可以參考下
    2021-06-06
  • Java中Lambda表達式和函數式接口的使用和特性

    Java中Lambda表達式和函數式接口的使用和特性

    Java Lambda表達式是一種函數式編程的特性,可簡化匿名內部類的寫法,與函數式接口搭配使用,實現(xiàn)代碼簡潔、可讀性高、易于維護的特點,適用于集合操作、多線程編程等場景
    2023-04-04
  • java和 javaw 及 javaws的區(qū)別解析

    java和 javaw 及 javaws的區(qū)別解析

    這篇文章主要介紹了java和 javaw 及 javaws的區(qū)別解析,本文通過實例給大家詳細介紹,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06

最新評論