MySQL與Oracle 差異比較之四條件循環語句


  • 循環語句
編號 類別 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;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM