JDBC入門(1)

来源:http://www.cnblogs.com/gdwkong/archive/2017/10/06/7631994.html
-Advertisement-
Play Games

JDBC(Java DataBase Connectivity,java資料庫連接)是一種用於執行SQL語句的Java API,可以為多種關係資料庫提供統一訪問,它由一組用Java語言編寫的類和介面組成。JDBC提供了一種基準,據此可以構建更高級的工具和介面,使資料庫開發人員能夠編寫資料庫應用程式, ...


   JDBC(Java DataBase Connectivity,java資料庫連接)是一種用於執行SQL語句的Java API,可以為多種關係資料庫提供統一訪問,它由一組用Java語言編寫的類和介面組成。JDBC提供了一種基準,據此可以構建更高級的工具和介面,使資料庫開發人員能夠編寫資料庫應用程式,同時,JDBC也是個商標名。

一、Java連接資料庫示例:

1、步驟:

  • 導jar包:驅動。
  • 載入驅動類:Class.forName("類名");
  • 給出url、username、password,其中url背下來。
  • 使用DriverManager類來得到Connection對象。
 1 public class Demo1 {
 2     /**
 3      * ClassNotFoundException:
 4      * 沒有導入驅動包
 5      *
 6      * SQLException:
 7      *  檢查三個參數:url、username、password是否正確
 8      *  檢查是否開啟了mysql伺服器。
 9      *
10      */
11     @Test
12     public void fun1() throws ClassNotFoundException,SQLException{
13         /**
14          * jdbc四大配置參數
15          *   driverClassName:com.mysql.jdbc.Driver
16          *   url:jdbc:mysql://localhost:3306/資料庫名
17          *   username:root
18          *   password:
19          */
20         Class.forName("com.mysql.jdbc.Driver");//載入驅動類(註冊驅動)
21 
22         //使用url、username、password,得到連接對象
23         Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb_1","root","");
24         System.out.println(con);
25     }
26 }

2、基本異常

未導驅動包:java.lang.ClassNotFoundException: com.mysql.jdbc.Driver ;

資料庫不存在:com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown database 'mydb';

埠錯誤:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure;

密碼錯誤:java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES);

用戶不存在:java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES);

二、JDBC原理

Class.forName("com.mysql.jdbc.Driver");//此據等同於以下麵兩句,與最後一句的邏輯關係
com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver;
DriverManager.registerDriver(driver);
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb_1","root","");

  所有的java.sql.Driver實現類,都提供了static塊,塊內的代碼就是把自己註冊到DriverManage中,如com.mysql.jdbc.Driver中的部分源碼:

public class Driver extends NonRegisteringDriver implements java.sql.Driver {
    //
    // Register ourselves with the DriverManager
    //
    static {
        try {
            java.sql.DriverManager.registerDriver(new Driver());
        } catch (SQLException E) {
            throw new RuntimeException("Can't register driver!");
        }
    }

    /**
     * Construct a new driver and register it with DriverManager
     * 
     * @throws SQLException
     *             if a database error occurs.
     */
    public Driver() throws SQLException {
        // Required for Class.forName().newInstance()
    }
}

  JDBC 4.0之後,每個驅動jar包中,在META-INF/services目錄下提供了一個名為java.sql.Driver的文件,文件的內容就是該介面的實現類名稱。連接資料庫例子中,第20行“Class.forName("com.mysql.jdbc.Driver");”可省略不寫。

三、使用JDBC對資料庫進行簡單的增刪改查操作示例

  1 package demo2;
  2 
  3 import org.junit.Test;
  4 import java.sql.*;
  5 
  6 public class Demo2 {
  7     /*
  8     * 對資料庫進行增、刪、改操作
  9     * */
 10     @Test
 11     public void fun1() throws ClassNotFoundException,SQLException {
 12         /*
 13         * 一、得到Connection
 14         * 1、準備四個參數
 15         * 2、載入驅動類
 16         * 3、得到Connection
 17         * */
 18 
 19         String driverClassName = "com.mysql.jdbc.Driver";
 20         //jdbc協議的格式,jdbc:工商的名稱:子協議(由工商自己來規定)
 21         //對mysql而言,它的子協議結構://主機:埠號/資料庫名稱
 22         String url = "jdbc:mysql://localhost:3306/mydb1";
 23         String username = "root";
 24         String password = "";
 25         //載入驅動類
 26         Class.forName(driverClassName);
 27         //使用DriverManager,以及剩下的三個參數,得到Connection
 28         Connection con = DriverManager.getConnection(url, username, password);
 29         /*
 30         * 二、對資料庫做增刪改
 31         *1、通過Connection對象創建Statement
 32         *  Statement 語句的發送器,它的功能就是向資料庫發送sql語句,
 33         *2、調用它的int executeUpdate(String sql),它可以發送DML、DDL
 34         * */
 35         Statement stmt = con.createStatement();
 36 //        String sql = "INSERT INTO stu VALUES('0003','wangwu',88,'male')";
 37 //        String sql = "UPDATE stu SET name='zhaoliu',age=22,gender='female' WHERE " +
 38 //                "number='0003'";
 39         String sql = "DELETE FROM stu";
 40         int r = stmt.executeUpdate(sql);
 41         System.out.println(r);
 42     }
 43     /*
 44      * 執行查詢操作
 45      * */
 46      @Test
 47     public void fun2() throws ClassNotFoundException,SQLException {
 48 
 49          /*
 50          * 一、得到Connection
 51          * 二、得到Statement,發送select語句
 52          * 三、對查詢返回的"表格"進行解析
 53          * */
 54          /*
 55          * 一、得到連接
 56          * */
 57          String driverClassName = "com.mysql.jdbc.Driver";
 58          String url = "jdbc:mysql://localhost:3306/mydb1";
 59          String username = "root";
 60          String password = "";
 61 
 62          Class.forName(driverClassName);
 63          Connection con = DriverManager.getConnection(url,username,password);
 64          /*
 65          * 二、得到Statement,執行select語句
 66          * */
 67          Statement stmt = con.createStatement();
 68          /*
 69          *調用Statement的ResultSet rs = executeQuery(String querySql);
 70          * */
 71          ResultSet rs = stmt.executeQuery("SELECT * FROM emp");
 72          /*
 73          * 三、解析ResultSet
 74          * 1、把行游標移動到第一行,可以調用next()方法完成。
 75          * */
 76          while (rs.next()) { //把游標向下移動一行,並判斷下一行是否存在
 77              int empno = rs.getInt(1);//通過列編號來獲取該列的值
 78              String ename = rs.getString("ename");//通過列名稱來獲取該列的值
 79              double sal = rs.getDouble("sal");
 80 
 81              System.out.println(empno+","+ename+","+sal);
 82          }
 83          /*
 84          * 四、關閉資源
 85          * 倒關
 86          * */
 87          rs.close();
 88          stmt.close();
 89          con.close();//必須關,不關就死。
 90     }
 91     //規範化
 92     @Test
 93     public void fun3() throws Exception {
 94         Connection con = null;//定義引用
 95         Statement stmt = null;
 96         ResultSet rs = null;
 97         try {
 98             //一、得到Connection
 99             String driverClassName  = "com.mysql.jdbc.Driver";
100             String url = "jdbc:mysql://localhost:3306/mydb1";
101             String username = "root";
102             String password = "";
103             Class.forName(driverClassName);
104             con = DriverManager.getConnection(url,username,password);//實例化
105             //二、創建Statement
106             stmt = con.createStatement();
107             String sql = "SELECT * FROM emp";
108             rs = stmt.executeQuery(sql);//實例化
109             //三、迴圈遍歷rs,列印其中數據
110             //getString()和getObject()是通用的
111             int count = rs.getMetaData().getColumnCount();
112             while (rs.next()) {
113                 for (int i = 1; i <= count; i++) {
114                     System.out.print(rs.getString(i));
115                     if (i<count) {
116                         System.out.print(",");
117                     }
118                 }
119                 System.out.println();
120             }
121 
122         } catch (Exception e) {
123             throw new RuntimeException(e);
124         } finally {
125             //為了防止空指針異常發生,使用判斷語句
126             if(rs != null) rs.close();
127             if(stmt != null) stmt.close();
128             if(con != null) con.close();
129         }
130     }
131 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 面試題之C# 記憶體管理與垃圾回收 你說說C# 的記憶體管理是怎麼樣的 這句話我記了一個多禮拜了, 自從上次東北師大面試之後, 具體請看<隨便扯扯東北師大的面試>. 國慶閑著沒事, 就大概瞭解了一下, 其實大二學習C# 的時候接觸過, 只不過那會看的也看的懵懂, 我看的是vir in C#, 順便查了些 ...
  • WPF佈局控制項與子控制項的HorizontalAlignment/VerticalAlignment屬性之間的關係: 1、Canvas/WrapPanel控制項: 其子控制項的HorizontalAlignment/VerticalAlignment屬性無效。2、Grid控制項: 其子控制項的Horizont ...
  • 在C#中,值類型和引用類型是相當重要的兩個概念,必須在設計類型的時候就決定類型實例的行為。如果在編寫代碼時不能理解引用類型和值類型的區別,那麼將會給代碼帶來不必要的異常。很多人就是因為沒有弄清楚這兩個概念從而在編程過程中遇到了很多問題,在這裡博主淺談對值類型和引用類型的認識。 首先從概念上看,值類型 ...
  • 一、前言 久聞EF大名,之前做C/S產品用的是Dapper對SqlLite進行ORM。然後接觸公司授權系統後發現用的是EntityFramework對SQLSever進行ORM。授權系統里用的是DBFirst,增刪查改使用Linq To Entity,覺得非常方便。本篇篇幅較短,老司機可直接略過 二 ...
  • 1.post請求 2.get請求 3.ajax跨站請求 在處理函數中需要加入:context.Response.AppendHeader("Access-Control-Allow-Origin", "*"); ...
  • 1 概述 1 概述 本篇文章主要是關於JqGrid的,主要功能包括使用JqGrid增刪查改,導入導出,廢話不多說,直接進入正題。 2 Demo相關 2 Demo相關 2.1 Demo展示 第一部分 第二部分 2.2 源碼和DB下載 國慶回來上傳到github上。 3 公共模塊 3 公共模塊 3.1 ...
  • 一、ResultSet之滾動結果集 ResultSet表示結果集,它是一個二維的表格。ResultSet內部維護一個行游標(游標),ResultSet提供了一系列的方法來移動游標: void beforeFirst():把游標放到第一行的前面,這也是游標預設的位置; void afterLast() ...
  • 一位從vb系轉到JAVA的朋友在一個類中寫了一個類似VB中MSGBOX的方法 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...