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; |