mysql之代碼執行結構

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

本文內容: 什麼是代碼執行結構 順序結構 分支結構 迴圈結構 首發日期:2018-04-18 什麼是代碼執行結構: 這裡所說的代碼執行結構就是多條sql語句的執行順序。 代碼執行結構主要用於觸發器、存儲過程和函數等存儲多條sql語句中。 順序結構: 順序結構就是從上到下依次執行sql語句 一般預設情 ...



本文內容:

  • 什麼是代碼執行結構
  • 順序結構
  • 分支結構
  • 迴圈結構

 

 首發日期:2018-04-18


什麼是代碼執行結構:

  • 這裡所說的代碼執行結構就是多條sql語句的執行順序。
  • 代碼執行結構主要用於觸發器、存儲過程和函數等存儲多條sql語句中。

 

 


順序結構:

  • 順序結構就是從上到下依次執行sql語句
  • 一般預設情況下都是順序結構

 

 


分支結構:

  • 分支結構的執行是依據一定的條件選擇執行路徑,它會依據我們給定的條件來選擇執行那些sql語句
  • mysql中分支結構只有if-else:
    • 語法:
      if 條件 then
          sql語句
      [elseif 條件 then
          sql語句]
      [else
       sql語句]
      end if;
    • 示例:
      -- 
      create table pass(id int primary key auto_increment,name varchar(15),score int );
      create table unpass(id int primary key auto_increment,name varchar(15),score int);
      
      -- 使用存儲過程來
      create procedure myif(in name varchar(15),in score int)
      begin
          if score >=60 then
              insert into pass(name,score) values(name,score);
          else
              insert into unpass(name,score) values(name,score);
          end if;
      end;
      -- 調用,並查看結果
      call myif("lilei",61);
      call myif("hanmeimei",95);
      select * from pass;
      select * from unpass;
      call myif("tuhao",59);
      select * from unpass;
    • if中的條件基本可以參照select語句的while子句的條件。什麼in\not in \= \!= 等都可以用。
      create procedure myif3(in a char(1))
      begin
          if a in('a','b') then
              select 1;
          else 
              select 2;
          end if;
      end;
      call myif3('a');
      call myif3('b');
      call myif3('c');

 

補充:

  • 理論上,如果做出判斷不符合,然而又不想繼續執行下去的時候,應該執行返回(比如C語言的return來中斷函數運行),但mysql中並沒有對應的中斷機制,所以需要我們主動中斷(中斷的方法有很多種,比如執行一條符合語法但無法運行的語句)【這種場景比如有:判斷一名學生是否存在,不存在就不執行任何操作,所以應該執行一條無法成功運行的語句來報錯返回。】
  • 事實上,還存在一種分支結構:case when 【好像好多書都沒怎麼講到,所以這裡不講述。有興趣的可以自行百度。】

 

 

 


迴圈結構:

 

    • 迴圈結構是指在程式中需要反覆執行某個功能而設置的一種程式結構。mysql中迴圈結構用於迴圈多次運行同一sql語句。
    • mysql中的迴圈結構有loop結構、while結構、repeat結構,這裡只講述while結構,有興趣瞭解其他的可以自行百度。
    • 語法:
while 條件 do
    sql語句
end while;
        學過其他語言的可能會瞭解到迴圈結構中有continue(提前結束此次迴圈)和break(跳出整個迴圈)
        在mysql的迴圈結構中,使用leave來代替break,使用iterate來代替continue,但它們的使用語法是:leave\iterate 迴圈名,所以如何定義迴圈名呢?
迴圈名:while 條件 do
    sql語句;
    leave\iterate 迴圈名;
end while;

 

  • 示例:
    -- 無意義的一個例子,僅作演示
    create table whilenum(id int);
    --  自帶條件的
    create procedure mywhile()
    begin
        declare num int;
        set num=10;
        c1:while num>0 do
                insert into whilenum values(num);
                set num=num-1;
            end while;
    end;
    -- 以傳入參數作為條件的
    create procedure mywhile2(in num int)
    begin
        c1:while num>0 do
                insert into whilenum values(num);
                set num=num-1;
            end while;
    end;
    -- 帶中斷的
    create procedure mywhile3(in num int)
    begin
        c1:while num>0 do
                if num%2=0 then
                    set num=num-1;
                    iterate c1;
                end if;
                insert into whilenum values(num);
                set num=num-1;
            end while;
    end;

 

 

 



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

-Advertisement-
Play Games
更多相關文章
  • 背景:查閱了一下MongoDB的相關文檔,發現中文文檔還是比較少的,工作中需要用到MongoDB,而這本《MongoDB最佳實踐》是很好的選擇,所以就把這本手冊翻譯了一下,其中生澀的專業用語是參考MongoDB中文官網進行翻譯,校對的時間比較少,難免會有不合理的地方,懇請大家指正。 簡介 Mongo ...
  • 範式 範式:Normal Format,是一種離散數學中的知識,是為瞭解決數據的存儲與優化的問題:保存數據的存儲之後,凡是能夠通過關係尋找出來的數據,堅決不再重覆存儲,終極目標是為了減少數據的冗餘。範式:是一種分層結構的規範,分為六層,每一層都比上一層更加嚴格,若要滿足下一層範式,前提是滿足上一層範 ...
  • ed2k://%7Cfile%7Ccn_sql_server_2008_r2_enterprise_x86_x64_ia64_dvd_522233.iso%7C4662884352%7C1DB025218B01B48C6B76D6D88630F541%7C/ ...
  • sudo /etc/init.d/mysql startmysql -u xxxx -p*****mysql >_ ...
  • 本文目錄: 1.非遞歸CTE 2.遞歸CTE 2.1 語法 2.2 遞歸CTE示例(1) 2.3 遞歸CTE示例(2) 2.4 遞歸CTE示例(3) 公用表表達式(Common Table Expression,CTE)和派生表類似,都是虛擬的表,但是相比於派生表,CTE具有一些優勢和方便之處。 C ...
  • 前言: 本文是對SQLSkills上一篇關於SQL Server中THREADPOOL等待的博客的翻譯,本文也不是完全翻譯,有些地方適當加入了自己的一些認知。如有翻譯不對或不好的地方,敬請指出,大家一起學習進步。尊重原創和翻譯勞動成果,轉載時請註明出處。謝謝! 英文原文地址:https://www.... ...
  • 第一種方法:一鍵修改LNMP環境下MYSQL資料庫密碼腳本 一鍵腳本肯定是非常方便。具體執行以下命令: ...
  • 已知條件如下: 插入數據如下: 既: 問題如下: Write an SQL query which returns for all current employees the start of their current period of continuous employment. That i ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...