婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > mysql代碼執行結構實例分析【順序、分支、循環結構】

mysql代碼執行結構實例分析【順序、分支、循環結構】

熱門標簽:云南大數據外呼系統 機器人打電銷電話 南寧外呼系統招商 博樂電銷機器人 鄭州網絡外呼系統價錢 400電話到哪辦理優惠 怎么更改高德地圖標注 上海市三維地圖標注 電話機器人是電腦呼號嗎

本文實例講述了mysql代碼執行結構。分享給大家供大家參考,具體如下:

本文內容:

  • 什么是代碼執行結構
  • 順序結構
  • 分支結構
  • 循環結構

 首發日期: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;

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • MySQL語句執行順序和編寫順序實例解析
  • 簡單了解mysql語句書寫和執行順序
  • 簡單了解MySQL SELECT執行順序
  • 有關mysql中sql的執行順序的小問題
  • SQL語句執行深入講解(MySQL架構總覽->查詢執行流程->SQL解析順序)
  • sql和MySQL的語句執行順序分析
  • 淺談mysql執行過程以及順序

標簽:恩施 白銀 寧夏 杭州 澳門 益陽 秦皇島 定西

巨人網絡通訊聲明:本文標題《mysql代碼執行結構實例分析【順序、分支、循環結構】》,本文關鍵詞  mysql,代碼,執行,結構,實例分析,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql代碼執行結構實例分析【順序、分支、循環結構】》相關的同類信息!
  • 本頁收集關于mysql代碼執行結構實例分析【順序、分支、循環結構】的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 高青县| 聊城市| 旬阳县| 犍为县| 常德市| 芜湖市| 远安县| 焦作市| 平昌县| 闻喜县| 怀安县| 璧山县| 黄平县| 开平市| 张掖市| 西和县| 荥阳市| 海盐县| 玉田县| 新巴尔虎右旗| 长阳| 罗平县| 乐陵市| 黑山县| 星座| 积石山| 马关县| 龙岩市| 石台县| 德惠市| 阿坝县| 田阳县| 天峻县| 聂拉木县| 乡城县| 呼图壁县| 清远市| 孟津县| 柞水县| 定远县| 井研县|