編號 |
類別 |
ORACLE |
MYSQL |
注釋 |
1 |
變數的聲明方式不同 |
li_index NUMBER := 0 |
DECLARE li_index INTEGER DEFAULT 0 |
1. mysql 使用DECLARE定義局部變數. 定義變數文法為: DECLARE var_name[,...] type [DEFAULT value] 要給變數提供一個預設值,需要包含一個DEFAULT子句。值可以被指定為一個運算式,不需要為一個常數。如果沒有DEFAULT子句,初始值為NULL。 |
2 |
變數的賦值方式不同 |
lv_inputstr := iv_inputstr |
SET lv_inputstr = iv_inputstr |
1. oracle變數賦值使用:= mysql 使用賦值使用set關鍵字. 將一個值賦給一個變數時使用"=". |
3 |
跳出(退出)語句不同 |
EXIT; |
LEAVE procedure name; |
1. oracle: 如果exit語句在迴圈中就退出當前迴圈.如果exit語句不再迴圈中,就退出當前過程或方法. Mysql: 如果leave語句後面跟的是預存程序名,則退出當前預存程序. 如果leave語句後面跟的是lable名. 則退出當前lable. |
while 條件 loop exit; end loop; |
label_name:while 條件 do leave label_name; end while label_name; |
4 |
定義遊標 |
TYPE g_grp_cur IS REF CURSOR; |
DECLARE cursor_name CURSOR FOR SELECT_statement; |
oracle可以先定義遊標,然後給遊標賦值. mysql定義遊標時就需要給遊標賦值. Mysql定義遊標出自 Mysql 5.1 參考手冊20.2.11.1.聲明游標. |
5 |
定義數組 |
TYPE unpacklist_type IS TABLE OF VARCHAR2(2000) INDEX BY BINARY_INTEGER; |
可以使用暫存資料表代替oracle數組, 也可以迴圈拆分字元來替代oracle數組. |
目前可以使用暫存資料表來代替oracle數組. 詳見<<2009002-OTMPPS-Difficult Questions-0001.doc>>中2.4 Mysql數組處理部分 |
6 |
注釋方式不同 |
"-- message" 或 "/** …. */" 或 "/* …. */" |
"-- message" 或 "/* …. */" 或 "#" |
mysql注釋來自 MySQL 5.1參考手冊 9.5. 注釋文法, 建議同oracle一樣, 單行用--, 多行/* */ |
7 |
內建日期時間函數格式不同 |
Oracle時間格式:yyyy-MM-dd hh:mi:ss |
Mysql時間格式:%Y-%m-%d %H:%i:%s |
1. MYSQL日期欄位分DATE和TIME兩種. ORACLE日期欄位只有DATE,包含年月日時分秒資訊. 2. mysql中取當前系統時間為now()函數,精確到秒. oracle中取當前資料庫的系統時間為SYSDATE, 精確到秒. |
8 |
日期加減 |
目前時間加N天: sysdate+N 目前時間減N天: sysdate-N |
日期相加: date_add(now(), INTERVAL 180 DAY) 日期相減: date_sub('1998-01-01 00:00:00', interval '1 1:1:1' day_second) |
|
9 |
字串串連符不同 |
result := v_int1||v_int2; |
set result = concat(v_int1,v_int2); |
1. oracle使用||連接字串,也可以使用concat函數. 但Oracle的concat函數只能串連兩個字串. Mysql使用concat方法連接字串. MySQL的concat函數可以串連一個或者多個字串,如 mysql> select concat('10'); 結果為: 10. mysql> select concat('11','22','33','aa'); 結果為: 112233aa 2. "||"在Mysql是與運算 |
10 |
定義遊標不同 |
CURSOR l_bk_cur IS SELECT B.BK_HDR_INT_KEY, B.BK_NUM FROM ES_SR_DTL_VRB A, ES_BK_HDR B WHERE A.BK_HDR_INT_KEY = B.BK_HDR_INT_KEY AND b.BK_STATUS != ES_BK_PKG.g_status_can AND A.SR_HDR_INT_KEY = ii_sr_hdr_int_key; |
DECLARE l_bk_cur CURSOR FOR SELECT B.BK_HDR_INT_KEY, B.BK_NUM FROM ES_SR_DTL_VRB A, ES_BK_HDR B WHERE A.BK_HDR_INT_KEY = B.BK_HDR_INT_KEY AND b.BK_STATUS != ES_BK_PKG.g_status_can AND A.SR_HDR_INT_KEY = ii_sr_hdr_int_key; |
詳見<<2009002-OTMPPS-Difficult Questions-0001.doc>>中2.2 Mysql遊標處理部分 |
11 |
交易回復 |
ROLLBACK; |
ROLLBACK; |
oracle和mysql中使用方法相同 |
12 |
GOTO語句 |
GOTO check_date; |
GOTO check_date; |
oracle和mysql中使用方法相同 |