mysql與oracle 差異比較之二基本語法
基本語法
編號 ? ? ? ? ? ? ? ?類別 ? ? ? ? ? ? ? ? ? ? ? ? ? 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語句在循環(huán)中就退出當前循環(huán).如果exit語句不再循環(huán)中,就退出當前過程或方法.
Mysql: 如果leave語句后面跟的是存儲過程名,則退出當前存儲過程. 如果leave語句后面跟的是lable名. 則退出當前l(fā)able.?
? ?
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數組,
也可以循環(huán)拆分字符來替代oracle數組. ? ?目前可以使用臨時表來代替oracle數組.?
詳見>中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;
? ?詳見>中2.2 Mysql游標處理部分 ? ?
11 ? ?事務回滾 ? ?ROLLBACK; ? ?ROLLBACK; ? ?oracle和mysql中使用方法相同 ? ?
12 ? ?GOTO語句 ? ?GOTO check_date; ? ?GOTO check_date; ? ?oracle和mysql中使用方法相同 ? ?
以上就是MySQL與Oracle 差異比較之二基本語法的內容,更多相關內容請關注PHP中文網(www.php.cn)!