MySQL存儲過程02

来源:https://www.cnblogs.com/wanghaoyu666/archive/2019/08/08/11322221.html
-Advertisement-
Play Games

這次接著說MySQL存儲過程: 我們先看它的多分支控制結構case: case的語句很簡單: case 變數名 when 條件1 then 輸出結果1; when 條件2 then 輸出結果2; ...... end case; 那我們就來建立一個存儲過程實現它: 由於我們設置的是隨機數,所以它會根 ...


這次接著說MySQL存儲過程:

我們先看它的多分支控制結構case:

case的語句很簡單: 

case 變數名

when 條件1 then 輸出結果1;

when 條件2 then 輸出結果2;

......

end case;

 

那我們就來建立一個存儲過程實現它:

create procedure p10()
begin
declare pos int default 0;
set pos:= floor(5*rand());
case pos
when 1  then select'我會飛';
when 2 then select'我掉到海裡';
when 3 then select'我在小島';
else select'我不知道我在哪';
end case;
end$

由於我們設置的是隨機數,所以它會根據我們生成的數來輸出結果

 

接著看一下repeat迴圈:

repeat的語法:

repeat

sql statement;

sql statement;

...

until condition end repeat;

create procedure p11()
begin
declare total int default 0;
declare i int default 0;
repeat
set i:=i+1;
set total:=total+i;
until i>=100 
end repeat;
select total;
end$

 

游標:

一條sql,對應N條資源,取出資源的介面/句柄,就是游標

沿著游標,可以一次取出一行。

建立游標的語法:

declare 游標名 cursor for sql語句;

open 游標名

fetch 游標名 into 變數1,變數2,...變數N;

close 游標名

create procedure p12()
begin
declare row_gid int;
declare row_name varchar(20);
declare row_num int;
declare getgoods cursor for select gid,num,name from goods;
open getgoods;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
close getgoods;
end$

 

那麼我們看到這個輸出結果沒有什麼特別的地方,那麼如果我們把游標改一改?

create procedure p13()
begin
declare row_gid int;
declare row_name varchar(20);
declare row_num int;
declare getgoods cursor for select gid,num,name from goods;
open getgoods;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
close getgoods;
end$

我們看到在輸出了三行之後報錯,那麼我們可以把迴圈和游標結合起來:

create procedure p14()
begin
declare row_gid int;
declare row_name varchar(20);
declare row_num int;
declare cnt int default 0; #聲明一個變數用來計數
declare i int default 0;
declare getgoods cursor for select gid,num,name from goods;
select count(*) into cnt from goods; #將總行數賦給cnt
open getgoods;
repeat
set i:=i+1;
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
until i>=cnt end repeat;
close getgoods;
end$

其實游標在越界時我們可以用declare continue handler 來操作一個越界標誌

declare continue handler for NOT FOUND 可執行語句;

create procedure p15()
begin
declare row_gid int;
declare row_name varchar(20);
declare row_num int;
declare you int default 1;
declare getgoods cursor for select gid,num,name from goods;
declare continue handler for NOT FOUND set you:=0;
open getgoods;
repeat
fetch getgoods into row_gid,row_num,row_name;
select row_num,row_name;
until you=0 end repeat;
close getgoods;
end$

在上面的結果中我們發現最後一行被取了兩次,這是為什麼?

答:因為我們聲明的是continue型handler,那麼它在把you 這個變數改為0後還會接著執行後面的sql語句,我們把continue改為exit就不會出現這種情況了:

create procedure p15()
begin
declare row_gid int default 0;
declare row_num int default 0;
declare row_name varchar(20);
declare you int default 1;
declare getgoods cursor for select gid,num,name from goods;
declare exit handler for NOT FOUND set you:=0;
open getgoods;
repeat
fetch getgoods into row_gid,row_num,row_name;
select row_name,row_num;
until you=0 end repeat;
close getgoods;
end$

那麼其實我們還有另一種方法來修改:我們使邏輯上更加通順

create procedure p17()
begin
declare row_gid int;
declare row_num int;
declare row_name varchar(20);
declare you int default 1;
declare getgoods cursor for select gid,num,name from goods;
declare continue handler for NOT FOUND set you:=0;
open getgoods;
fetch getgoods into row_gid,row_num,row_name;
repeat
select row_name,row_num;
fetch getgoods into row_gid,row_num,row_name;
until you=0 end repeat;
close getgoods;
end$

或者是將repeat改為while迴圈,在這裡我就不列舉了。


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

-Advertisement-
Play Games
更多相關文章
  • 剛開始學習linux操作系統是總是很茫然,無所適從,以下是自己總結的工作經驗,僅供參考! 一、準備資源 安裝前需要準備的資源有linux系統centos7.6發行版系統鏡像,vmware workstations15 模擬安裝虛擬機工具。 二、安裝步驟 1, 安裝VMware workstation ...
  • 1 電腦的基本硬體組成 早期,DIY一臺電腦,要先有三大件 CPU 記憶體 主板 1.1 CPU 電腦最重要的核心配件,中央處理器(Central Processing Unit)。 電腦的所有“計算”都是由CPU來進行的。 CPU是一個超級精細的印刷電路版 1.2 記憶體(Memory) 你撰 ...
  • 任何程式都需要載入到記憶體才能與CPU進行交流 同理, 位元組碼.class文件同樣需要載入到記憶體中,才可以實例化類 的使命就是提前載入.class 類文件到記憶體中 在載入類時,使用的是Parents Delegation Model(溯源委派載入模型) Java的類載入器是一個運行時核心基礎設施模塊, ...
  • 1.事件簡介 事件(event)是MySQL在相應的時刻調用的過程式資料庫對象。一個事件可調用一次,也可周期性的啟動,它由一個特定的線程來管理的,也就是所謂的“事件調度器”。 事件和觸發器類似,都是在某些事情發生的時候啟動。當資料庫上啟動一條語句的時候,觸發器就啟動了,而事件是根據調度事件來啟動的。 ...
  • 以下示例在 SQL Server 實例上創建了一個資料庫。該資料庫包括一個主數據文件、一個用戶定義文件組和一個日誌文件。主數據文件在主文件組中,而用戶定義文件組包含兩個次要數據文件。ALTER DATABASE 語句將用戶定義文件組指定為預設文件組。然後通過指定用戶定義文件組來創建表。 ...
  • 作者: Dominik Moritz, Bill Howe, Jeffrey Heer 發表於CHI 2019, 三位作者都來自於University of Washington Interactive Data Lab 項目代碼: 簡介 Linked Visualization(鏈接可視化系統)是 ...
  • 本文主要瞭解了MySQL關係型資料庫和SQL語言的基本知識。 ...
  • 在windows環境下!!!! 1.找到my.inc文件,不是你的安裝目錄路徑,是C:\ProgramData\MySQL\MySQL Server 5.7這個路徑,註意 ProgramData 文件夾是隱藏的需要顯示出來!!! C:\ProgramData\MySQL\MySQL Server 5 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...