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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...