JDBC簡介

来源:http://www.cnblogs.com/fjkgrbk/archive/2017/01/03/java_jdbc.html
-Advertisement-
Play Games

jdbc連接資料庫的四個對象 DriverManager 驅動類 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建議使用 原因有2個: > 導致驅動被註冊2次。 > 強烈依賴資料庫的驅動jar 解決辦法: Class.forNa ...


jdbc連接資料庫的四個對象

DriverManager  驅動類     

       DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建議使用

           原因有2個:

                        > 導致驅動被註冊2次。

                        > 強烈依賴資料庫的驅動jar

             解決辦法:

                      Class.forName("com.mysql.jdbc.Driver");

 Connection  連接類

   static Connection getConnection(String url, String user, String password)

           試圖建立到給定資料庫 URL 的連接。

          getConnection("jdbc:mysql://localhost:3306/day06", "root", "root");

          URL:SUN公司與資料庫廠商之間的一種協議。

                 jdbc:mysql://localhost:3306/day06

                協議 子協議  IP :埠號 資料庫

                   資料庫類型

                          mysql: jdbc:mysql://localhost:3306/day14 或者 jdbc:mysql:///day14(預設本機連接)

                          oracle: jdbc:oracle:thin:@localhost:1521:sid

            getConnection(String url, Properties info)

                  Properties info = new Properties();//要參考資料庫文檔  可以用文件代替

                  info.setProperty("user", "root");//用戶名

                  info.setProperty("password","root");//密碼

    //獲取連接對象返回值connection

   Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/day14?user=root&password=root");

Statement  操作資料庫類

           //創建操作資料庫對象

       Statement state=conn.createStatement();

     String sql="sql語句";

    Result rt= state.executeQuery(sql);//返回結果集

      問題:存在sql註入

      解決辦法

         使用傳入參數方式 防止sql註入
Statement (PreparedStatement)//預編譯對象PreparedStatement

    特點:

           1.性能要高

           2.會把sql語句先編譯

           3.sql語句中的參數會發生變化,過濾掉用戶輸入的關鍵字。

  Statement state= conn.preparedStatement();

       String sql="select * from user where username=? and password=?";

       Result rt= state.executeQuery(sql);//返回結果集

       state.setString(1,username);

       state.setString(2,password);

      執行對象返回的結果
         ResultSet executeQuery();
         int executeUpdate();
         boolean execute();

         delete from users where id=?
         ps.setInt(1,5);


ResultSet 結果集

  結果集(客戶端存表數據的對象)

           //獲取數據

            next();

            getString();
            getDouble();
            getDate();

總結
利用四個核心對象編寫代碼


try{
              //載入驅動
              Class.forName("com.mysql.jdbc.Driver");
              //創建連接Connection
              Connection conn = DriverManager.getConnection("jdbc:mysql:///day06","root","abc");
              //得到執行sql的statement對象
              //conn.createStatement();
              PreparedStatement ps = conn.prepareStatement("select * from users where name=? and pwd=?");
              ps.setString(1,"tom");
              ps.setString(2,"123");
              //執行語句,並返回結果
              ResultSet rs = ps.executeQuery();
              //處理結果
             while(rs.next()){
                  User u = new User();
                  u.setId(rs.getInt(1));
                     .... }
                       }

          catch(Exception e){
              e.printSt...  }

          finally{
            //關閉資源
            if(rs!=null)
            {rs.close();}
            if(ps!=null)
            {ps.close();}
            if(conn!=null)
            {conn.close();}
               }


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

-Advertisement-
Play Games
更多相關文章
  • hello ...
  • 本文詳細介紹了C#製作簡易屏保的步驟,以及筆者在學習過程中的一些心得,有需要的可以參考下。 ...
  • Redis 安裝 & 配置 本測試環境將在 CentOS 7 x64 上安裝最新版本的 Redis。 1. 運行以下命令安裝 Redis 如果 CentOS 上提示 wget 命令未找到,則先安裝 net-tools。 yum install net-tools 2. Redis 配置文件 1)開啟 ...
  • 一.使用背景 1. SignalR是什麼? ASP.NET SignalR 是為 ASP.NET 開發人員提供的一個庫,可以簡化開發人員將實時 Web 功能添加到應用程式的過程。實時 Web 功能是指這樣一種功能:當所連接的客戶端變得可用時伺服器代碼可以立即向其推送內容,而不是讓伺服器等待客戶端請求 ...
  • 此Demo是採用VS自帶的Chart圖表控制項,製作實時動態顯示的折線圖,和波形圖。 涉及到知識如下: Chart 控制項,功能強大,可以繪製柱狀圖,折線圖,波形圖,餅狀圖,大大簡化了對圖的開發與定製。 Chart控制項的相關概念: ChartArea,表示圖表區域,一個Chart可以繪製多個ChartA ...
  • 在IIS上安裝Kooboo CMS Kooboo CMS安裝之後 安裝的常見問題 1. 在IIS上安裝Kooboo CMS Kooboo CMS部署到正式環境相當簡單,安裝過程是一個普通MVC站點在IIS上的架設過程,沒有額外的配置步驟。首先從 "這裡" 下載最新版本的Kooboo CMS安裝包以備 ...
  • 反射 System.Reflection 命名空間下的類與 System.Type 命名空間使你能夠獲取有關載入的程式集和其中定義的類型的有關信息,如類、介面和值類型等。 可以使用反射在運行時創建、調用和訪問類型實例。 CLR 程式管理應用程式域,應用程式域構成具有相同應用程式範圍的對象周圍定義的邊 ...
  • 不知道在博客園寫過的文章是否可以更改,特此測試!!! ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...