mysql之存儲過程

来源:https://www.cnblogs.com/progor/archive/2018/04/17/8866574.html
-Advertisement-
Play Games

本文內容: 什麼是存儲過程 存儲過程的創建 存儲過程的使用 查看存儲過程 修改存儲過程 刪除存儲過程 首發日期:2018-04-17 什麼是存儲過程: 存儲過程存儲了一系列sql語句 存儲過程的需求場景:下邊是一個經典的需求場景,很多Mysql的書都有: 存儲過程存儲了一系列sql語句,使得簡化了操 ...



本文內容:

  • 什麼是存儲過程
  • 存儲過程的創建
  • 存儲過程的使用
  • 查看存儲過程
  • 修改存儲過程
  • 刪除存儲過程

 

 

首發日期:2018-04-17


什麼是存儲過程:

 

  • 存儲過程存儲了一系列sql語句
  • 存儲過程的需求場景:下邊是一個經典的需求場景,很多Mysql的書都有:image
  • 存儲過程存儲了一系列sql語句,使得簡化了操作,不要求重覆執行一系列操作只需要在需要的時候調用一下存儲過程就行了。
  • 一般來說,可以認為存儲過程的功能與函數的功能類似(應該都學過函數吧),但只是要註意存儲過程沒有返回值,所以可以依據函數可用場景來理解存儲過程。

 

 

補充:

  • 存儲過程與觸發器的區別:觸發器觸發事件就執行一系列語句;而存儲過程是調用,而且存儲過程還要根據情況考慮執行“另外一系列語句”。
  • 存儲過程與函數的區別:函數有返回值,而存儲過程沒有【所以不能使用在select語句中】

 


存儲過程的創建:

  • create procedure 存儲過程名 ([參數列表])  begin   sql 語句  end;
    • 參數列表的格式:[類型限定 變數名 數據類型]
      • 參數列表有自己的類型限定,這個類型限定與數據類型不同,它是限定參數的作用範圍
        • in:限定這個參數是傳值給存儲過程,既然是傳值,所以可以是變數或常量數據【in修飾的參數一般是傳入存儲過程中作為某些條件的,不會被存儲過程修改
        • out:限定這個參數是存儲過程傳出的一個值,因為有值的返回,所以這個參數必須是一個變數【存儲過程中會給out修飾的變數賦值,使得過程外部可以獲取這個更改的值】
        • inout:inout是上面兩者的疊加,既可以被存儲過程內部使用,又可以修改後被外部使用,因為有值的返回,所以這個參數必須是一個變數

 

  • 理論上,對於希望簡潔代碼的地方都可以使用存儲過程來處理,比如希望快速使用多條select,又比如希望從數據中取出多個值賦值給變數;所以下麵只給出用法,應用場景就不講述了。
    • 1:不傳入參數,只執行某些特定代碼
    • 2.傳入參數,並利用參數作為條件執行代碼
    • 3.傳入參數,並利用參數作為條件執行代碼,同時利用變數獲取結果。
    • 【下麵的call是調用過程】
-- 最簡單的例子
create procedure myselect()
begin 
    select @@version;
end;
create procedure getInfo(in mname varchar(15))
begin 
select mname;
end;
call myselect();
call getInfo("lilie");
-- 能通過傳參來獲取指定內容的
create procedure getInfo2(in mname varchar(15))
begin 
select * from student where name =mname;
end;
call getInfo2("lilei");
-- 將結果賦值給一個變數傳到外部
create procedure getInfo3(in mname varchar(15),out oname varchar(15))
begin 
select name from student where name =mname into oname;
end;
call getInfo3("lilei",@mname);
select @mname;

 

 

補充:

  • 與觸發器類似,如果在命令行模式下進行存儲過程創建,需要修改命令結束符。
  • 還可以有一些特別的選項,特別的選項寫在([參數列表])  之後,begin之前
    • comment:是這個存儲過程的一個描述
      create procedure myselect2()
      comment "我的一系列sql語句"
      begin 
          select * from student;
          select * from class;
      end;
      show create procedure myselect2;
    • 還有一些比如sql security等選項,有興趣可以自行百度。這裡不講解,僅一提有此知識點。

 

 


存儲過程的使用:

 

  • 調用存儲過程:call 存儲過程名();
  • 帶參數的調用存儲過程:call 存儲過程名(參數);
    • 對於in類型的,參數可以是數值,可以是變數
    • 對於out\inout類型的,參數必須是變數
    • 所有MySQL變數都必須以 @ 開始
    • 示例:call myselect("lilei",@變數名);示例:call myselect(@變數名,@變數名)

 

下麵調用的存儲過程就是上面創建存儲過程中定義的存儲過程:

call myselect();

call getInfo("lilie");

set @mname="lilei";
call getInfo(@mname);

call getInfo3("lilei",@mname);

 

變數的使用:

  • out和inout能修改會被存儲過程修改的變數,但這個修改會在存儲過程調用結束後才會成功修改【就好像如果在過程內部現有一條命令是修改的,可以在此命令後面查看一下變數,發現全局變數並沒有改變,改變的只是局部變數】。
  • 所有MySQL變數都必須以 @ 開始
  • 存儲過程中,使用局部變數可以使用select 變數名;使用全局變數可以使用select @變數名;
  • 關於具體變數的定義與使用將在我的另外一篇博文中講解。超鏈接:mysql之變數

 


查看存儲過程:

  • 查看存儲過程的創建語句:show create procedure 存儲過程名;
  • 查看存儲過程狀態:show procedure status;【顯示的內容包括創建時間、註釋、定義的用戶、安全類型等等】

 


修改存儲過程:

  • 修改存儲過程只能修改那些選項(這裡不講解那些具體選項,想瞭解的可以自行百度),並不能修改傳入傳出參數或者sql語句。
  • alter procedure 存儲過程名 選項;
    • image

刪除存儲過程:

  • 語法:drop procedure 存儲過程名;
  • 示例:
  • drop procedure getInfo;

 



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

-Advertisement-
Play Games
更多相關文章
  • 今兒有位同事提出,一套MySQL 5.6的環境,從資料庫伺服器本地登錄,一切正常,可是若從遠程伺服器訪問,就會報錯, ERROR 1045 (28000): Access denied for user 'bisal'@'x.x.x.x' (using password: YES) 我才開始接觸My ...
  • 本文內容: 系統變數 用戶變數 局部變數 局部變數 首發日期:2018-04-18 系統變數: 系統變數就是系統已經提前定義好了的變數 系統變數一般都有其特殊意義。比如某些變數代表字元集、某些變數代表某些mysql文件位置 系統變數中包括會話級變數(當次會話連接生效的變數,如names),以及全局變 ...
  • 本文目錄:1.創建、修改視圖2.視圖演算法merge、temptable3.刪除、查看視圖信息4.檢查無效視圖 視圖是表表達式的一種,所以它也是虛擬表。對視圖操作的時候會通過語句動態的從表中臨時獲取數據。 1.創建、修改視圖 當使用or replace時,如果視圖存在則此語句相當於alter view ...
  • ################# HA 即 High Available 高可用。# 其作用是為了減少主從結構的單點故障,而設置備用節點,既然學習了Hadoop生態圈,那麼HA配置也是必須要掌握的。# 因為生產環境中,一定會設置HA,減少故障率。 # 參考了好幾處的教程,自己動手實踐了下,成功。 ...
  • 本文目錄:1.創建觸發器2.insert觸發器3.delete觸發器4.update觸發器5.通過on duplicate key update分析觸發器觸發原理6.replace to演算法驗證7.查看、刪除觸發器 觸發器用來實現在永久表上進行某些操作時觸發啟動另一操作。 1.創建觸發器 以下是Ma ...
  • 大家都知道,在MySQL中刪除一個表中的記錄有兩種方法,一種是DELETE FROM TABLENAME WHERE... , 還有一種是TRUNCATE TABLE TABLENAME。 DELETE FROM 從 MySQL 數據表中刪除數據,如果沒有指定 WHERE 子句,MySQL 表中的所 ...
  • 目前最流行的資料庫: oracle、mysql、sqlserver、db2、sqline --:單行註釋 #:也是單行註釋 /* 註釋內容*/:多行註釋 mysql -uroot -p密碼:登錄mysql service mysqld restart重啟mysql /etc/my.cnfmysql的 ...
  • https://blog.csdn.net/weixin_41950448/article/details/79939554 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...