MySQL與Oracle 差異比較之四條件迴圈語句,mysqloracle

來源:互聯網
上載者:User

MySQL與Oracle 差異比較之四條件迴圈語句,mysqloracle

迴圈語句

編號 類別 ORACLE MYSQL 注釋
1 IF語句使用不同 IF iv_weekly_day = 'MON'THEN
       ii_weekly_day := 'MON';
ELSIF iv_weekly_day = 'TUE' THEN
       ii_weekly_day := 'TUE';
END IF;
IF iv_weekly_day = 'MON'THEN
      set ii_weekly_day = 'MON';
ELSEIF iv_weekly_day = 'TUE' THEN
      set ii_weekly_day = 'TUE';
END IF;  
1. mysql和oracle除了關鍵字有一個字差別外(ELSEIF/ELSIF),if語句使用起來完全相同. 
2. mysql if語句文法: 摘自 MySQL 5.1 參考手冊 20.2.12.1. IF語句 
IF search_condition THEN statement_list
    [ELSEIF search_condition THEN statement_list] ...
    [ELSE statement_list]
END IF
IF實現了一個基本的條件構造。如果search_condition求值為真,相應的SQL語句列表被執行。如果沒有search_condition匹配,在ELSE子句裡的語句列表被執行。statement_list可以包括一個或多個語句。
2 FOR語句不同 FOR li_cnt IN 0..(ii_role_cnt-1) LOOP
    SELECT COUNT(*) INTO li_role_ik_cnt FROM SD_ROLE
    WHERE ROLE_CD = lo_aas_role_upl(li_cnt);
    IF li_role_ik_cnt = 0  THEN
        RETURN 'N';
    END IF;
    li_role_ik_cnt := -3;
END LOOP; 
loopLable:LOOP
  IF i > (ii_role_cnt-1) THEN
    LEAVE looplable;
  ELSE
    SELECT COUNT(*) INTO li_role_ik_cnt FROM SD_ROLE
    WHERE ROLE_CD = 'ADMIN_SUPER'; /*lo_aas_role_upl(li_cnt);*/
    IF li_role_ik_cnt = 0  THEN
       RETURN 'N';
    END IF;
    SET li_role_ik_cnt = -3;
    SET i = i+1;
   END IF;
 END LOOP loopLable;

1. oracle使用For語句實現迴圈. 
   Mysql使用Loop語句實現迴圈. 
2. oracle 使用For…loop關鍵字. 
   Mysql使用loopLable:LOOP實現迴圈. 
3 while語句不同 WHILE lv_inputstr IS NOT NULL LOOP
...
END LOOP;
WHILE lv_inputstr IS NOT NULL DO
...
END WHILE;
1. oracle 中使用while語句關鍵字為: while 運算式 loop… end loop;
    mysql 中使用while語句關鍵字為: while 運算式 do… end while;

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.