SQL基礎隨記2 視圖 存儲過程

来源:https://www.cnblogs.com/G-Aurora/archive/2020/06/26/13196872.html
-Advertisement-
Play Games

SQL基礎隨記2 視圖 存儲過程 View CREATE/ALTER/DROP VIEW ViewName as SELECT(...) 可以在視圖的基礎上繼續創建視圖,即,將之前創建的視圖當做表名放在新視圖的select語句中 利用視圖進行數據格式化(就是對欄位進行重新組合與拼接) CREATE ...


SQL基礎隨記2 視圖 存儲過程

 

View

  • CREATE/ALTER/DROP VIEW ViewName as SELECT(...)
    
  • 可以在視圖的基礎上繼續創建視圖,即,將之前創建的視圖當做表名放在新視圖的select語句中

  • 利用視圖進行數據格式化(就是對欄位進行重新組合與拼接)

    CREATE VIEW View_player_team AS 
    SELECT CONCAT(player_name, '(' , team.team_name , ')') AS player_team
    FROM player JOIN team WHERE player.team_id = team.team_id
    
  • 視圖具有安全性,因為視圖是虛擬表,即使對視圖做出了修改,也不會影響底層數據。

 

PROCEDURE

  • 存儲過程就像“自定義函數”,它是SQL語句和流控制語句的集合,它可以接受參數,也可以返回參數。

  • 存儲過程可以(不是一定)直接對底層數據表進行操作

  • CREATE PROCEDURE name(參數)
    BEGIN
    	需要執行的過程
    END
    

    舉例1,

    DELIMITER //
    
    CREATE PROCEDURE `存儲過程名`(形參)
    BEGIN
    	迴圈體
    END //
    
    DELIMITER;
    

    調用存儲過程舉例

    CALL `存儲過程名`(實參);
    select @(out參數)
    
    • DELIMITER是將分隔符變為 // (也可以使用其他的),因為流控制語句中的語句需要;分割,此舉是避免混淆

    • 開頭和結尾的DELIMITER都是另起一行mysql shell

    • 存儲過程名用的不是單引號,是英文的 "頓點"

    • 流控制語句

      DECLIARE --- 聲明變數
      SET --- 初始化,賦值
      IF...ELSE...
      
      REPEAT...UNTIL...END REPEAT --- 滿足UNTIL後面的表達式則退出迴圈
      WHILE...DO...END WHILE --- 先判斷條件,滿足則迴圈
      CONTINUT;
      BREAK;
      RETURN;
      GOTO (label)
      WAITFOR TIME 'time' --- 在某個時刻執行
      WAITFOR DELAY 'time' --- 延遲某個時間執行
      SELECT...INTO... --- 將查詢表中的結果放入變數中
      
  • 參數類型

    • IN --- 傳入參數,無法返回,不寫參數類型預設為IN
    • OUT --- 將存儲過程的計算結果放入OUT參數中並用於返回
    • INOUT --- 既用於傳入參數又可以將結果存入該參數中用於返回
  • PROCEDURE的優點

    • 安全性強,設定存儲過程的時候可以設置對用戶的使用許可權
    • 執行效率快,在MySQL資料庫伺服器端執行
    • 通過封裝,減少網路傳輸量
  • PROCEDURE的缺點 --- 阿裡等公司不推薦使用的原因

    • 調試困難,僅少部分DBMS支持調試
    • 可移植性差
    • 版本管理困難
    • 不適合高併發場景 --- 高併發需要減小資料庫壓力,可能會採用分庫分表的方式且對拓展性要求高。在這種情況下,存儲過程變得難以維護且會增加資料庫的壓力

 

procedure 舉例1 按某個欄位對錶進行查詢

  • 查看已有測試表

    mysql> SELECT * FROM t; 
    +----+------+
    | Id | nums |
    +----+------+
    |  1 |    2 |
    +----+------+
    1 row in set (0.00 sec)
    

    創建存儲過程

    mysql> DELIMITER //
    mysql> CREATE PROCEDURE `findByNums`(IN n int)
        -> BEGIN
        -> SELECT * FROM t WHERE nums = n;
        -> END //
    Query OK, 0 rows affected (0.03 sec)
    

    檢驗

    mysql> DELIMITER ;
    mysql> CALL findByNums(2);
    +----+------+
    | Id | nums |
    +----+------+
    |  1 |    2 |
    +----+------+
    1 row in set (0.03 sec)
    
    Query OK, 0 rows affected (0.03 sec)
    

    (傳入不同參數)

    mysql> CALL findByNums(1);
    Empty set (0.00 sec)
    
    Query OK, 0 rows affected (0.00 sec)
    

     

  • 查詢存儲過程

    mysql> SELECT * FROM mysql.proc WHERE db = 'test' AND type = 'procedure';
    

 

procedure 舉例2 計算累和結果

  • 使用存儲過程傳入/傳出參數查詢輸出

    mysql> delimiter //
    mysql> create procedure `add_sum`(in n int, out result int)
        -> begin
        -> declare i int;
        -> declare sum int;
        -> set i = 1;
        -> set sum = 0;
        -> while i < n do
        -> set sum = sum + i;
        -> set i = i + 1;
        -> end while;
        -> end //
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> delimiter ;
    mysql> call add_sum(50,@result);
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> select @result;
    +---------+
    | @result |
    +---------+
    |    1225 |
    +---------+
    1 row in set (0.00 sec)
    
    
  • 無法直接@存儲過程中的變數

    mysql> create procedure `add_sum_procedure`(in n int)
        -> begin
        -> declare i int;
        -> declare sum int;
        -> set i = 1;
        -> set sum = 0;
        -> while i < n do
        -> set sum = sum + i;
        -> set i = i + 1;
        -> end while;
        -> end //
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> delimiter ;
    mysql> call add_sum_procedure(10);
    Query OK, 0 rows affected (0.01 sec)
    
    mysql> select @sum;
    +------+
    | @sum |
    +------+
    | NULL |
    +------+
    1 row in set (0.01 sec)
    

查詢所有存儲過程/視圖 等等

 


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

-Advertisement-
Play Games
更多相關文章
  • 發文前,說下寫這個的緣故。本來以為自己對java內部類瞭解,其實是我太過於不覺得、以為不重要!所以,今天在重新寫下Demo,為自己記錄一下、回顧一下。 開始~~~ 重新理解什麼是內部類以及寫法、定義等; 代碼一: 1 package com.yk.nbn; 2 /** 3 * @author yk ...
  • 完整逆波蘭計算器(Java) 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 功能 支持 + - * / ( ) 多位數,支持小數, 相容處理, 過濾任何空白字元,包括空格、製表符、換頁符 基本思路 中綴表達式轉尾碼表達式 代碼 ...
  • 最近在寫一個小工具,裡面用到了一個自定義的類,並且需要對該類進行多個實例化。 因為需要根據需求來取不同的實例,所以決定將其放置到一個字典中,以便取用。 另外,由於可能之後會改動實例化時的內容,所以準備將具體實例化的代碼封裝到一個單獨的子程式中,以便更改。 所以寫瞭如下的代碼: 1 namespace ...
  • 一、layui.use 1、LayUI的官方使用文檔:https://www.layui.com/doc/ 2、layui的內置模塊不是預設就載入好的,必須要執行啟動模塊的這種方法後模塊才會載入; 3、layui.use就是一種載入模塊的方式。如下代碼: //LayUI渲染以及啟動模塊 layui. ...
  • 今天是農曆五月初五,端午節。在此,祝大家端午安康! 端午節是中華民族古老的傳統節日之一。端午也稱端五,端陽。此外,端午節還有許多別稱,如:午日節、重五節、五月節、浴蘭節、女兒節、天中節、地臘、詩人節、龍日等。 不好意思,跑題了,就此打住。 事情的經過是這樣的,今年端午節公司給每位員工都準備了一個粽子 ...
  • Java工具類——包裝類 我們都知道,JDK 其實給我們提供了很多很多 Java 開發者已經寫好的現成的類,他們其實都可以理解成工具類,比如我們常見的集合類,日期相關的類,數學相關的類等等,有了這些工具類,你會發現它能很大程度的幫你節省時間,能很方便的實現你的需求。當然,沒有這些包,你也能實現你的需 ...
  • STM32一種使用HAL,DMA,IDLE,POLLING的方式來處理UART的不定長接收機制 設備接收數據 (DMA) 採用的HAL庫,同時在UART初始化的時候添加DMA相關操作,在系統開始運行時,開始使用HAL_UART_Receive_DMA來啟動UART的接收,同時需要定義一個接收的buf ...
  • 首先我們來看看mariadb的鎖定概念,所謂鎖就是當一個進程或事務在操作某一資源時,為了防止其他用戶或者進程或事務對其進行資源操作,導致資源搶占而發生衝突,通常在A進程操作該資源時,會對該資源進行加鎖,實現多進程或多用戶操作同一資源時,不會發生衝突;通常情況鎖的類型分讀鎖和寫鎖,所謂讀鎖就是共用鎖... ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...