day45-JDBC和連接池01

来源:https://www.cnblogs.com/liyuelian/archive/2022/10/13/16789610.html
-Advertisement-
Play Games

JDBC和連接池01 1.JDBC概述 基本介紹 JDBC為訪問不同的資料庫提供了同一的介面,為使用者屏蔽了細節問題 Java程式員使用JDBC,可以連接任何提供了jdbc驅動程式的資料庫系統,從而完成對資料庫的各種操作 jdbc原理圖 JDBC是java提供的一套用於資料庫操作的介面API,Jav ...


JDBC和連接池01

1.JDBC概述

  • 基本介紹
  1. JDBC為訪問不同的資料庫提供了同一的介面,為使用者屏蔽了細節問題
  2. Java程式員使用JDBC,可以連接任何提供了jdbc驅動程式的資料庫系統,從而完成對資料庫的各種操作
  • jdbc原理圖

    JDBC是java提供的一套用於資料庫操作的介面API,Java程式員只需要面向這套介面編程即可。不同的資料庫廠商需要針對這套介面,提供不同的實現。

image-20221013171158077

jdbc模擬實現

模擬JDBC驅動:

package jdbc.myjdbc;

/**
 * 我們規定的jdbc介面(方法)規範
 */
public interface JdbcInterface {
    //連接
    public Object getConnection();
    //crud
    public void crud();
    //關閉連接
    public void close();
}

模擬Mysql驅動:

package jdbc.myjdbc;

/**
 * 模擬 mysql資料庫實現jdbc介面[由mysql廠商開發]
 */

public class MysqlJdbcImpl implements JdbcInterface{

    @Override
    public Object getConnection() {
        System.out.println("得到 mysql 的連接");
        return null;
    }

    @Override
    public void crud() {
        System.out.println("完成 mysql 的增刪改查");

    }

    @Override
    public void close() {
        System.out.println("關閉 mysql 的連接");
    }
}

模擬Oracle驅動:

package jdbc.myjdbc;

/**
 * 模擬實現oracle的連接驅動-即實現規範介面
 */
public class OracleJdbcImpl implements JdbcInterface{
    @Override
    public Object getConnection() {
        System.out.println("得到 oracle 的連接");
        return null;
    }

    @Override
    public void crud() {
        System.out.println("完成 oracle 的增刪改查");
    }

    @Override
    public void close() {
        System.out.println("關閉 oracle 的連接");
    }
}

模擬java程式使用各種資料庫驅動連接資料庫:

package jdbc.myjdbc;

public class TestJdbc {
    public static void main(String[] args) {
        //完成mysql的操作
        JdbcInterface jdbcInterface = new MysqlJdbcImpl();
        jdbcInterface.getConnection();// 通過介面來調用實現類[動態綁定]
        jdbcInterface.crud();
        jdbcInterface.close();
        System.out.println("==============");
        //完成oracle的操作
        jdbcInterface = new OracleJdbcImpl();
        jdbcInterface.getConnection();// 通過介面來調用實現類[動態綁定]
        jdbcInterface.crud();
        jdbcInterface.close();
    }
}
image-20221013170400028
  • JDBC API

jdbc api是一系列的介面,它統一和規範了應用程式與資料庫的連接、執行SQL語句,並得到返回結果等各類操作,相關類和介面在java.sql與javax.sql包中。

image-20221013172741263

image-20221013173433675 image-20221013173351385

2.JDBC快速入門

2.1JDBC程式編寫步驟

  1. 註冊驅動 -- 載入Driver類

  2. 獲取連接 -- 得到Connection

  3. 執行增刪改查 -- 發送SQL命令給mysql執行

  4. 釋放資源 -- 關閉相關連接

image-20221013191133183

例子--通過jdbc對錶actor進行添加,刪除和修改操作

  1. 首先在SQL yog使用mysql資料庫創建一個演員actor表
-- 創建測試表 演員表
CREATE TABLE actor(
	id INT PRIMARY KEY AUTO_INCREMENT,
	`name` VARCHAR(32) NOT NULL DEFAULT '',
	sex CHAR(1) NOT NULL DEFAULT '女',
	borndate DATETIME,
	phone VARCHAR(12)
);

SELECT * FROM actor;
  1. 下載mysql連接驅動
image-20221013180819855
  1. 在項目中創建libs文件夾,將驅動複製進文件夾中,右鍵點擊驅動,選擇ad as library

    image-20221013180938559
  2. 在彈出的視窗中點擊OK,即可

    image-20221013181134041
package li.jdbc;

import com.mysql.jdbc.Driver;

import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

/**
 * 這是第一個jdbc程式,完成簡單的操作
 */
public class jdbc01 {
    public static void main(String[] args) throws SQLException {
        //前置工作:在項目下創建一個文件夾如 libs
        //將mysql.jar拷貝到該目錄下,點擊add to project.. 加入到項目中

        //1.註冊驅動
        Driver driver = new Driver();//創建一個driver對象

        //2.得到連接
        /**
         * jdbc:mysql://  是規定好的協議,表示通過jdbc的方式來連接mysql
         * localhost 表示要連接到的主機ip地址
         * 3306 表示mysql監聽的埠
         * hsp_db02 表示連接到 mysql DBMS的哪個資料庫
         */
        // mysql的連接本質就是socket的連接
        String url = "jdbc:mysql://localhost:3306/hsp_db02";

        //將用戶名和密碼放入到一個Properties對象中
        Properties properties = new Properties();
        // user 和 password 是規定好的,後面的值根據實際情況寫
        properties.setProperty("user", "root");//用戶
        properties.setProperty("password", "123456");//密碼

        Connection connect = driver.connect(url, properties);

        //3.執行sql
        String sql = "insert into actor values(null,'劉德華','男','1970-11-11','110')";
        //String sql = "update actor set name ='周星馳' where id = 1 ";
        //String sql = "delete from actor where id = 1 ";
        //Statement 用於執行靜態SQL語句並返回其生成的結果的對象
        Statement statement = connect.createStatement();
        int rows = statement.executeUpdate(sql);//如果是dml語句,返回的就是影響的行數
        System.out.println(rows > 0 ? "成功" : "失敗");

        //4.關閉連接資源
        statement.close();
        connect.close();
    }
}
image-20221013190759096

在SQL yog中執行語句查詢,發現actor表中成功插入一條數據

image-20221013190805770

2.2資料庫連接的5種方式

2.2.1方式1

//獲取Driver實現類對象
Driver driver = new com.mysql.jdbc.Driver();

String url = "jdbc:mysql://localhost:3306/jdbc_db";

Properties info = new Properties();
info.setProperty("user", "root");//用戶
info.setProperty("password", "123456");//密碼
Connection conn = driver.connect(url,info);
System.out.println(conn);

2.2.2方式2

方式1會直接使用com.mysql.jdbc.Driver(),屬於靜態載入,靈活性差,依賴性強

方式2使用反射機制進行動態載入,而且信息可以放入配置文件中保存,更利於項目的控制

image-20221013195335018

例子

package li.jdbc;

//分析java連接mysql的5種方式

import com.mysql.jdbc.Driver;
import org.junit.Test;

import java.sql.Connection;
import java.util.Properties;

public class jdbcConn {
    //方式2
    @Test
    public void connect02() throws Exception {
        //使用反射載入Driver類,動態載入,更加地靈活,減少依賴性
        Class<?> aClass = Class.forName("com.mysql.jdbc.Driver");
        Driver driver = (Driver)aClass.newInstance();

        String url = "jdbc:mysql://localhost:3306/hsp_db02";
        //將 用戶名和密碼 放入到 Properties對象中
        Properties properties = new Properties();
        // user 和 password 是規定好的,後面的值根據實際情況寫
        properties.setProperty("user", "root");//用戶
        properties.setProperty("password", "123456");//密碼
        Connection connect = driver.connect(url, properties);
        System.out.println("方式2="+connect);
    } 
}

2.2.3方式3

在方式2的基礎上使用DriverManager替換Driver

image-20221013195451224 image-20221013194254770 image-20221013194304939 image-20221013194646959

例子

package li.jdbc;

import com.mysql.jdbc.Driver;
import org.junit.Test;

import java.sql.Connection;
import java.sql.DriverManager;

public class jdbcConn {

    //方式3 使用DriverManager替換Driver進行統一管理
    @Test
    public void connect03() throws Exception {
        //使用反射載入Driver類
        Class<?> aClass = Class.forName("com.mysql.jdbc.Driver");
        Driver driver = (Driver)aClass.newInstance();
        //創建 url和 user 和 password
        String url = "jdbc:mysql://localhost:3306/hsp_db02";
        String user = "root";
        String password = "123456";

        DriverManager.registerDriver(driver);//註冊Driver驅動
        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("方式3="+connection);
    }
}

2.2.4方式4

使用Class.forName自動完成註冊驅動,簡化代碼

image-20221013195528865

例子

//方式4 使用Class.forName自動完成註冊驅動,簡化代碼
    // 這種方式獲取連接是使用得最多的,推薦使用
    @Test
    public void connect04() throws Exception {
        //使用反射載入Driver類
        //在載入Driver類時,完成了註冊
        /**
         * 在 Driver類的源碼中:
         * 1.靜態代碼塊在類載入時會執行一次
         * 2.DriverManager.registerDriver(new Driver());
         * 3.因此 註冊Driver的工作已經在底層完成了
         *  static {
         *         try {
         *             DriverManager.registerDriver(new Driver());
         *         } catch (SQLException var1) {
         *             throw new RuntimeException("Can't register driver!");
         *         }
         *     }
         */
        Class.forName("com.mysql.jdbc.Driver");

        //創建 url和 user 和 password
        String url = "jdbc:mysql://localhost:3306/hsp_db02";
        String user = "root";
        String password = "123456";

        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("方式4="+connection);
    }

方法4相比於方法3,減少了註冊驅動的操作,但是連接資料庫的步驟不是需要註冊驅動嗎?為什麼可以這樣呢?

在Driver類的源碼中,我們可以看到有這樣的一個靜態代碼塊:

image-20221013200814126

而靜態代碼塊在類載入時會執行一次,在使用反射載入Driver類時,就執行了DriverManager.registerDriver(new Driver());語句。

即在載入Driver類時,完成了註冊。因此,可以在程式中省略註冊的步驟。

註意:

  1. mysql驅動5.1.6之後連Class.forName("com.mysql.jdbc.Driver");也不需要寫了

  2. 從jdk1.5以後使用了jdbc4,不再需要顯式調用Class.forName()註冊驅動,而是自動調用驅動jar包下的META-INF\services\java.sql.Driver文本中的類名稱去註冊

    image-20221013202326519
  3. 但是還是建議寫上Class.forName("com.mysql.jdbc.Driver");,更加明確

2.2.5方式5

在方式4的基礎上使用配置文件,連接資料庫更加靈活

image-20221013202553145 image-20221013202611605

例子

首先在src文件夾下麵創建一個Properties文件

user=root
password=123456
url=jdbc:mysql://localhost:3306/hsp_db02
driver=com.mysql.jdbc.Driver

方式5:推薦使用

  //方式5 在方式4的基礎上使用配置文件,連接資料庫更加靈活
    @Test
    public void connect05() throws Exception {
       //通過Properties對象拿到配置文件的信息
        Properties properties = new Properties();
        properties.load(new FileInputStream("src\\mysql.properties"));
        //獲取相關的值
        String user = properties.getProperty("user");
        String password = properties.getProperty("password");
        String url = properties.getProperty("url");
        String driver = properties.getProperty("driver");

        Class.forName(driver);//建議寫上
        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("方式5="+connection);

    }

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

-Advertisement-
Play Games
更多相關文章
  • 一、HTTPS協議概念 超文本傳輸安全協議(Hypertext Transfer Protocol Secure,簡稱:HTTPS)是一種通過電腦網路進行安全通信的傳輸協議。HTTPS經由HTTP進行通信,利用SSL/TLS來加密數據包。HTTPS的主要目的是提供對網站伺服器的身份認證,保護交換數 ...
  • Vue組件 數據源 //這裡是HTML內容 這裡通過下麵的引入框架結構把數據源傳到框架中 還有匹配項 <Mytable :configList="configList" :configData="configData"></Mytable> // 引入結構組件 import myCard from ...
  • 概念 performance.now():返回值表示為從time origin之後到當前調用時經過的時間, time origin: 時間源, 時間源是一個可以被認定為當前文檔生命周期的開始節點的標準時間,計算方法如下: 如果腳本的 global object 是 Window, 則時間源的確定方式 ...
  • 在前面隨筆《基於SqlSugar的開發框架循序漸進介紹(12)-- 拆分頁面模塊內容為組件,實現分而治之的處理》中我們已經介紹過,對於相關的業務表的界面代碼,我們已經儘可能把不同的業務邏輯封裝在不同的頁面組件中,隔離變化的差異,因此界面組件化後,就可以利用代碼生成工具進行統一的界面代碼的生成了,而且... ...
  • 應用集成是解決各個系統之間信息共用中最基礎和最重要的一步。我國的商業銀行都擁有繁多、複雜的應用系統,重覆開發的情況嚴重,而且不能很好地跨系統共用數據或功能,不利於金融創新能力的提升。本文主要介紹了應用集成的發展階段,和如何運用集成技術與方式解決系統的煙囪問題,以及相比較之下的優點與局限性。還請各路專... ...
  • 對於在父類中存在的屬性,如果要在其派生類中繼續擴展屬性 可以這樣實現 1 class Valley: 2 def __init__(self): 3 self._name = None 4 5 @property 6 def name(self): 7 return self._name 8 9 @ ...
  • 數組操作 1. 數組和 for 迴圈不得不說的秘密 數組是一個連續數據存儲空間,同時帶有下標性質操作,下標範圍是 0 ~ 數組容量 - 1 ==> 利用迴圈來進行操作。 // 利用 for 迴圈給予數組中的每一個元素進行賦值操作 // 利用 for 迴圈展示數組中的每一個元素數據存儲內容 class ...
  • Kafka介紹 Kafka是最初由Linkedin公司開發,是一個分散式、支持分區的(partition)、多副本的(replica),基於zookeeper協調的分散式消息系統,它的最大的特性就是可以實時的處理大量數據以滿足各種需求場景:比如基於hadoop的批處理系統、低延遲的實時系統、Stor ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...