您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關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; |
感謝各位的閱讀!關于“MySQL與Oracle 差異比較之條件循環語句的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。