真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

什么是mysql代碼執(zhí)行結(jié)構(gòu)

小編這次要給大家分享的是什么是MySQL代碼執(zhí)行結(jié)構(gòu),文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

創(chuàng)新互聯(lián)公司主營三江侗網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶App定制開發(fā),三江侗h5小程序設(shè)計搭建,三江侗網(wǎng)站營銷推廣歡迎三江侗等地區(qū)企業(yè)咨詢

本文內(nèi)容:

  • 什么是代碼執(zhí)行結(jié)構(gòu)
  • 順序結(jié)構(gòu)
  • 分支結(jié)構(gòu)
  • 循環(huán)結(jié)構(gòu)

 首發(fā)日期:2018-04-18


什么是代碼執(zhí)行結(jié)構(gòu):

  • 這里所說的代碼執(zhí)行結(jié)構(gòu)就是多條sql語句的執(zhí)行順序。
  • 代碼執(zhí)行結(jié)構(gòu)主要用于觸發(fā)器、存儲過程和函數(shù)等存儲多條sql語句中。

順序結(jié)構(gòu):

  • 順序結(jié)構(gòu)就是從上到下依次執(zhí)行sql語句
  • 一般默認情況下都是順序結(jié)構(gòu)

分支結(jié)構(gòu):

  • 分支結(jié)構(gòu)的執(zhí)行是依據(jù)一定的條件選擇執(zhí)行路徑,它會依據(jù)我們給定的條件來選擇執(zhí)行那些sql語句
  • mysql中分支結(jié)構(gòu)只有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;
      -- 調(diào)用,并查看結(jié)果
      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');
         

補充:

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

循環(huán)結(jié)構(gòu):

    • 循環(huán)結(jié)構(gòu)是指在程序中需要反復執(zhí)行某個功能而設(shè)置的一種程序結(jié)構(gòu)。mysql中循環(huán)結(jié)構(gòu)用于循環(huán)多次運行同一sql語句。
    • mysql中的循環(huán)結(jié)構(gòu)有l(wèi)oop結(jié)構(gòu)、while結(jié)構(gòu)、repeat結(jié)構(gòu),這里只講述while結(jié)構(gòu),有興趣了解其他的可以自行百度。
    • 什么是mysql代碼執(zhí)行結(jié)構(gòu)
    • 語法:
while 條件 do
 sql語句
end while;
      • 學過其他語言的可能會了解到循環(huán)結(jié)構(gòu)中有continue(提前結(jié)束此次循環(huán))和break(跳出整個循環(huán))
      • 在mysql的循環(huán)結(jié)構(gòu)中,使用leave來代替break,使用iterate來代替continue,但它們的使用語法是:leave\iterate 循環(huán)名,所以如何定義循環(huán)名呢?
循環(huán)名:while 條件 do
 sql語句;
 leave\iterate 循環(huán)名;
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;
    -- 以傳入?yún)?shù)作為條件的
    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;

看完這篇關(guān)于什么是mysql代碼執(zhí)行結(jié)構(gòu)的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。


當前標題:什么是mysql代碼執(zhí)行結(jié)構(gòu)
文章轉(zhuǎn)載:http://weahome.cn/article/iiojhj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部