SQL快速入門 ( MySQL快速入門, MySQL參考, MySQL快速回顧 )

来源:https://www.cnblogs.com/lihuanqing/archive/2018/09/16/9657345.html
-Advertisement-
Play Games

SQL 先說點廢話,很久沒發文了,整理了下自己當時入門 SQL 的筆記,無論用於入門,回顧,參考查詢,應該都是有一定價值的,可以按照目錄各取所需。SQL資料庫有很多,MySQL是一種,本文基本都是SQL通用標準,有些標準很不統一的地方就用MySQL的寫法了。希望本文幫你快速瞭解SQL的基本操作和概念 ...


SQL

先說點廢話,很久沒發文了,整理了下自己當時入門 SQL 的筆記,無論用於入門,回顧,參考查詢,應該都是有一定價值的,可以按照目錄各取所需。SQL資料庫有很多,MySQL是一種,本文基本都是SQL通用標準,有些標準很不統一的地方就用MySQL的寫法了。希望本文幫你快速瞭解SQL的基本操作和概念。
文章格式上有些問題,可以點擊這裡獲得更加的閱讀體驗

目錄

檢索

  • 檢索某表中單個列:
    SELECT 列名
    FROM 表名;
  • 檢索某表中多個列:
    SELECT 列名,列名,列名
    FROM 表名;
  • 檢索某表中所有列:(儘量不用)
    SELECT *
    FROM 表名;
  • 只檢索某表中某列里不重覆的項:
    SELECT DISTINCT 列名 (如果有兩列或以上,需要這些列組合起來是不重覆的)
    FROM 表名;
  • 檢索指定行數:
    SELECT 列名
    FROM 表名
    LIMIT 5 OFFSET n; (mySQL中,選第n行後的五行。 OFFSET n 可不填寫預設為0,其它 SQL 資料庫中有不同寫法)

過濾檢索結果

  • 尋找指定行:(舉例)
    SELECT prod_name, prod_price  
    FROM Products  
    WHERE prod_price = 3.49;(和字元串比較加單引號,數值不用)
查找列名為prod_name和列名為prod_price的兩列,檢索其中prod_price = 3.49; 的所有行。  
= 可以替換為其它操作符,如下表

| 操作符 | 描述 |
| --- | --- |
| = | 等於 |
| <> | 不等於 |
| > | 大於 |
| < | 小於 |
| >= | 大於等於 |
| <= | 小於等於 |
| BETWEEN | 在某個範圍內 |
| LIKE | 搜索某種模式 |
  • 組合WHERE子句:
    SELECT prod_id, prod_price, prod_name
    FROM Products
    WHERE vend_id = 'DLL01' AND prod_price <= 4;
AND 連接同時需要滿足的兩個條件,OR即滿足一個條件即可,NOT 找到與後邊條件不匹配的行。  
且not,and和or可以組合使用,用小括弧聲明邏輯循序。  
`WHERE vend_id IN ( 'DLL01', 'BRS01' ) `  
IN 起到作用類似於or,速度更快,邏輯更清晰。
  • 通配符搜索:
    SELECT prod_id, prod_name
    FROM Products
    WHERE prod_name LIKE '%bean bag%';
%表示任意字元出現任意次數。也可以出現在中間位置。  
_ 表示一個字元。  
[charlist] 表示包含在裡面的任意字元,[^charlist]不包含在裡面的任意字元。
少使用通配符,搜索速度較慢。  

數據彙總處理

  • 算術計算:
    SELECT prod_id,
            quantity,
            item_price,
            quantity * item_price AS expanded_price
    FROM OrderItems
    WHERE order_num = 20008;
`expanded_price`成為計算出來的新列。
  • 字元串拼接:
    不同資料庫有差異,MySQL中:
    SELECT concat(vend_name , vend_country)
            AS vend_title
    FROM Vendors
    ORDER BY vend_name;
concat_ws( ':' , vend_name , vend_country) 形式第一個參數為分隔符。  
其他資料庫用+或者||拼接字元串。
  • 日期時間處理不同資料庫差異較大。
  • 內置方法:
    • 求平均值:
      SELECT AVG(prod_price) AS avg_price
      FROM Products;
      表Products中prod_price的平均值。返回給 avg_price。
      可以配合WHERE語句計算指定行的平均值。
    • 求最大值:MAX(prod_price)
    • 求最小值:MIN(prod_price)
    • 求和:SUM(prod_price)
    • 近似的小數點後幾位:ROUND(column_name,decimals)
    • 當前日期: Now()
    • 求行數:
      SELECT COUNT(*) AS num_cust
      FROM Customers;
      求表Customers有幾行。返回給num_cust。
      *可以換成指定列如:cust_email。計算所得行數不包括該列值為null的行。
      DISTINCT 列名,求不重覆的列。
  • 組合:
    SELECT COUNT(*) AS num_items,
           MIN(prod_price) AS price_min,
           MAX(prod_price) AS price_max,
           AVG(prod_price) AS price_avg
    FROM Products;

分組

  • 創建分組:
    SELECT vend_id
    FROM Products
    GROUP BY vend_id;
根據 vend_id列中內容對 vend_id分組,  
第一行換成 `SELECT vend_id, COUNT(*) AS num_prods` 即對每一個組計算行數。  
註意:多行NULL會分為一組,GROUP BY子句必須出現在WHERE子句之後,ORDER BY子句之前。  
可以對一個以上的列進行 GROUP BY
  • 過濾分組:
    HAVING:類似於WHERE。唯一的差別是,WHERE過濾行,而HAVING過濾分組。
    SELECT vend_id, COUNT(*) AS num_prods
    FROM Products
    WHERE prod_price >= 4
    GROUP BY vend_id
    HAVING num_prods >= 2;
過濾出有(兩個價格大與4的產品)的供應商

給檢索結果排序

SELECT Company, OrderNumber 
FROM Orders 
ORDER BY Company DESC, OrderNumber ASC  

可以 ORDER BY 列名1,列名2; 先按列名1內容排序,排序結果相同的按列名2內容排序。
列名後接 DESC 按該列內容倒序排列,ASC 正序(預設)。
ORDER BY 命令放在查詢、分組等語句的最後。

表操作

  • 創建表:
    CREATE  TABLE  newProducts
    (
        prod_id         CHAR(10)           NOT NULL,
        vend_id         CHAR(10)           NOT NULL,
        prod_name       CHAR(254)          NOT NULL,
        prod_price      DECIMAL(8,2)       NOT NULL,
        prod_desc       VARCHAR(1000)      NULL
    );
NOT NULL 非空約束,不允許列中有NULL值下麵介紹其他約束。  
列的設置可以加上預設值,如NOT NULL後邊接 DEFAULT  CURRENT_DATE() ,預設值為當前日期。(每個資料庫獲取當前日期語句不同。)
後面接 PRIMARY KEY 即設置改列為主鍵。
後面接  AUTO_INCREMENT 即設置為自增,只有int型可以設置。
  • 約束:
    每個列可以有一種或幾種約束。
    • NOT NULL 非空約束.
    • UNIQUE 唯一約束,可唯一標識資料庫表中的每條記錄。
    • PRIMARY KEY 主鍵約束,唯一標識資料庫表中的每條記錄,唯一且非空。
    • FOREIGN KEY 外鍵約束,一個表中的 FOREIGN KEY 指向另一個表中的 PRIMARY KEY。
    • CHECK 檢查約束,用於限制列中的值的範圍。
    • DEFAULT 預設約束,用於向列中插入預設值
      每個表可以有多個 UNIQUE 約束,但是每個表只能有一個 PRIMARY KEY 約束。
      每種約束可以創建表時設置好,也可以後期增刪.
  • 索引:
    在不讀取整個表的情況下,索引使資料庫應用程式可以更快地查找數據。
    CREATE INDEX 索引名
    ON Person (列名[,列名])  
  • 複製表或表中部分列:
    CREATE  TABLE CustCopy AS
    SELECT * FROM Customers;
創建Customers表的複製,CustCopy。
  • 修改表:
    ALTER TABLE Vendors
    ADD vend_phone CHAR(20);
    ALTER TABLE Vendors
    DROP COLUMN vend_phone;
各資料庫有不相容現象,複雜表操作列可能要新建表刪除舊表。  
ALTER 還可以用來添加刪除約束,刪除索引等。
  • 刪除表:
    DROP TABLE CustCopy;
  • 重命名錶:
    RENAME Table oldTable TO newTable;

插入數據

  • 插入整行或部分行:
    INSERT INTO Customers(cust_id,
                            cust_name,
                            cust_address,
                            cust_city,
                            cust_state,
                            cust_zip,
                            cust_country,
                            cust_contact,
                            cust_email)
    VALUES('1000000007',
            'Toy Land',
            '123 Any Street',
            'New York',
            'NY',
            '11111',
            'USA',
            NULL,
            NULL);
插入整行時,可省略 Customers 括弧內的內容,即按照列的順序,分別插入數據(不推薦)。省略 Customers 括弧內的內容時,無內容的列必須用NULL占位。  
插入部分行時,把要插入的列填入 Customers 括弧內,與VALUES內容一一對應,沒有提到的列預設NULL或其他預設值。
  • 插入查詢到的值:
    INSERT INTO Customers(cust_id,
                            cust_contact,
                            cust_email,
                            cust_name,
                            cust_address,
                            cust_city,
                            cust_state,
                            cust_zip,
                            cust_country)
    SELECT cust_id,
            cust_contact,
            cust_email,
            cust_name,
            cust_address,
            cust_city,
            cust_city,
            cust_state,
            cust_zip,
            cust_country
    FROM CustNew;
把從CustNew表中查到的內容插入 Customers表中。一次插入多行的方式。

更新和刪除數據:

  • 更新數據:
    UPDATE Customers
    SET cust_email = '[email protected]'
    WHERE cust_id = '1000000005';
步驟為,要更新的表,要更新的列,要更新的行。一個SET可以跟多個列用逗號隔開。  
刪除某個值,即設置他為NULL。
  • 刪除數據:
    DELETE FROM Customers
    WHERE cust_id = '1000000008';
刪除表中指定整行,刪除部分列用UPDATE  
在UPDATE或DELETE語句使用WHERE子句前,應該先用SELECT進行測試,保證它過濾的是正確的記錄,以防編寫的WHERE子句不正確。如果不寫WHERE會更新或刪除所有行內容。

子查詢-迭代查詢

  • 一種形式:
    SELECT cust_name, cust_contact
    FROM Customers
    WHERE cust_id IN (SELECT cust_id
        FROM Orders
        WHERE order_num IN (SELECT order_num
            FROM OrderItems
            WHERE prod_id = 'RGAN01'));
先從第二個括弧選擇符合條件的order_num,成為第二個括弧內容,再向上找到第一個括弧,查到符合條件的cust_id返回給第一個括弧,最後根據第一個括弧內容執行主查詢語句。性能問題不要嵌套太多層。  
也就是對Customers表的查詢要用到Orders表查詢後返回的內容,對Orders表的查詢要用到OrderItems表查詢後返回的內容。
  • 另一種形式:
    SELECT cust_name,
        cust_state,
        (SELECT COUNT(*)
            FROM Orders
            WHERE Orders.cust_id = Customers.cust_id) AS orders
    FROM Customers
根據Customers 表中的cust_id,去Orders表中取得計算後的數據。  
  • 同一個表迭代查詢:
    SELECT cust_id, cust_name, cust_contact
    FROM Customers
    WHERE cust_name = (SELECT cust_name
                    FROM Customers
                    WHERE cust_contact = 'Jim Jones');

聯結-關聯多個表

  • 兩個表:
    • 內聯結
          SELECT vend_name, prod_name, prod_price
          FROM Vendors, Products
          WHERE Vendors.vend_id = Products.vend_id;
      根據兩個表共同的列vend_id把Vendors, Products關聯起來。
      與
          SELECT vend_name, prod_name, prod_price
          FROM Vendors INNER JOIN Products
          ON Vendors.vend_id = Products.vend_id;
      結果相同。都是內聯結,前一種是後一種的簡寫。  
      INNER 可省略。
    • 外聯結:
          SELECT Customers.cust_id, Orders.order_num
          FROM Customers LEFT OUTER JOIN Orders
          ON Orders.cust_id = Customers.cust_id;
      LEFT OUTER JOIN 把Customers表中沒有被匹配到的 cust_id 也聯結進去(會顯示在結果里)。  
      RIGHT OUTER JOIN 是把Orders表中沒有被匹配到的 cust_id 也聯結進去(會顯示在結果里)。  
      FULL OUTER JOIN 會把兩張表中沒有匹配到的列也顯示出來(mysql 不支持,可通過 UNION 實現)
      OUTER 可省略。
  • 多個表:
    SELECT cust_name, cust_contact
    FROM Customers, Orders, OrderItems
    WHERE Customers.cust_id = Orders.cust_id
    AND OrderItems.order_num = Orders.order_num
    AND prod_id = 'RGAN01';
作用同子查詢中a。同樣不要關聯太多,有性能問題。其中表名可以使用別名,如:  
    SELECT cust_name, cust_contact
    FROM Customers AS C, Orders AS O, OrderItems AS OI
    WHERE C.cust_id = O.cust_id
    AND OI.order_num = O.order_num
    AND prod_id = 'RGAN01';

組合查詢

SELECT cust_name, cust_contact, cust_email 
FROM Customers 
WHERE cust_state IN ('IL','IN','MI') 
UNION ALL
SELECT cust_name, cust_contact, cust_email 
FROM Customers 
WHERE cust_name = 'Fun4All';

UNION ALL 鏈接兩句查詢語句,統一返回結果,包含重覆結果。
去掉ALL以後,去掉重覆結果。
此處(從同一個表中查詢)可以用WHERE , OR代替。
常用作從不同表中查詢時,只要列數相同就可以拼接到一起,列名按照第一句中查詢的列名。

視圖

對已存在的表,進行篩選,數據處理,聯結等操作後返回的數據,創建的虛擬表。視圖是為了重用和簡化常用的查詢。對視圖的查詢同表。
視圖總是顯示最近的數據。每當用戶查詢視圖時,資料庫引擎通過使用 SQL 語句來重建數據。

  • 創建視圖:
    CREATE  VIEW ProductCustomers AS                
    SELECT cust_name, cust_contact, prod_id
    FROM Customers, Orders, OrderItems
    WHERE Customers.cust_id = Orders.cust_id
    AND OrderItems.order_num = Orders.order_num;
對OrderItems, Orders和Customers三個表進行聯結,聯結後結果形成 ProductCustomers 視圖,可以把它當一張表來查詢。
  • 刪除視圖:
    DROP VIEW ProductCustomers;

    其它

  • 存儲過程:為以後的使用保存一條或多條SQL語句,用於簡化操作。每個資料庫不同,見資料庫具體介紹。
  • 事務處理:事務處理模塊中的語句,或者全部執行,或者全部不執行。可以設立保留點,執行失敗時回到保留點。
  • 創建資料庫: CREATE DATABASE database_name
  • 刪除資料庫:DROP DATABASE 資料庫名稱


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

-Advertisement-
Play Games
更多相關文章
  • 一、完全公平調度演算法 完全公平調度 CFS 的出發點基於一個簡單的理念:進程調度的效果應該如同系統具備一個理想中的完美多任務處理器。在這種系統中,每個進程能夠獲得 1/n 的處理器時間(n 為可運行進程數)。同時,我們可以調度給它們無限小的時間周期,所以,在任何可測量周期內,我們給予 n 個進程中每 ...
  • 在工作中,我們往往需要遠程伺服器,經常會遇到以下這兩個麻煩事。 一、遠程桌面的連接數限制,超出系統就會提示超過連接數。 二、遠程桌面連接時,同一個用戶不能同時遠程2個桌面連接。 為瞭解決這兩個麻煩事情,我們只需要配置Server 2008 R2的遠程桌面授權服務即可。實驗操作配置如下: 此次實驗的前 ...
  • 關於什麼是服務掃描不多介紹,通俗來看: 我已經掃描到目標機器某個埠開放,接下來我需要知道開放這個埠的是什麼應用 情景: 我的Kali機器IP地址:192.168.22.130 我要掃描的Metasploitable機器IP地址:192.168.22.129 1.先介紹一個小工具:不強大,但是可以 ...
  • 虛擬機Linux與本地虛擬網卡配置 NAT鏈接方式 **********這是我親自嘗試多次實踐出來的結果,不是複製粘貼************************* 首先進行初始化,這樣避免有些設置會有影響 第二步,如圖中1,取消本地DHCP服務,2、這裡的子網ip要與虛擬機內部的網段相同,最後 ...
  • VPN英文全稱是“Virtual Private Network”,就是“虛擬專用網路”。可以遠程幫助用戶、分公司、商業伙伴及供應商同公司的內部網建立可信的安全連接,用於經濟有效地連接到商業伙伴和用戶的安全外聯網虛擬專用網。 搭建環境: 伺服器系統:Windows server 2008 R2 客戶 ...
  • 一.概述 在linux中,很多程式和腳本都通過環境變數來獲取系統信息,存儲臨時數據,配置信息。環境變數是指用來存儲有關shell會話和工作環境信息,允許你在記憶體中存儲數據,以便程式或shell中運行的腳本能夠輕鬆訪問到它們。也是存儲持久數據的一種簡便方法。在bash shell中,環境變數分為:全局 ...
  • 載入和動態鏈接 從編譯/鏈接和運行的角度看,應用程式和庫程式的連接有兩種方式。 一種是固定的、靜態的連接,就是把需要用到的庫函數的目標代碼(二進位)代碼從程式庫中抽取出來,鏈接進應用軟體的目標映像中; 另一種是動態鏈接,是指庫函數的代碼並不進入應用軟體的目標映像,應用軟體在編譯/鏈接階段並不完成跟庫 ...
  • 一 需求 隨著公司業務的發展,資料庫實例也逐漸增多,資料庫也會越來越多,有時候我們會發現正式生產資料庫也測試資料庫數據不一致,也有可能是預發佈環境下的資料庫與其他資料庫架構不一致,或者,分散式資料庫上線,發現某些不可預知的原因,也會導致資料庫之間架構不一致等等。因此,在複雜的資料庫對象中,迅速全部找 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...