濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL與Oracle差異比較之二 基本語法

MySQL與Oracle差異比較之二 基本語法

熱門標(biāo)簽:泗洪正規(guī)電話機(jī)器人找哪家 河北便宜電銷機(jī)器人軟件 怎么申請400熱線電話 ai電話電話機(jī)器人 南昌呼叫中心外呼系統(tǒng)哪家好 湖南保險智能外呼系統(tǒng)產(chǎn)品介紹 小程序智能電話機(jī)器人 簡單的智能語音電銷機(jī)器人 怎么去開發(fā)一個電銷機(jī)器人

基本語法

編號 類別 ORACLE MYSQL 注釋
1 變量的聲明方式不同 li_index NUMBER := 0 DECLARE li_index INTEGER DEFAULT 0 1. mysql 使用DECLARE定義局部變量. 
   定義變量語法為:  DECLARE var_name[,...] type [DEFAULT value] 要給變量提供一個默認(rèn)值,需要包含一個DEFAULT子句。值可以被指定為一個表達(dá)式,不需要為一個常數(shù)。如果沒有DEFAULT子句,初始值為NULL。   
2 變量的賦值方式不同 lv_inputstr := iv_inputstr SET lv_inputstr = iv_inputstr 1. oracle變量賦值使用:=  
   mysql 使用賦值使用set關(guān)鍵字. 將一個值賦給一個變量時使用"=". 
3 跳出(退出)語句不同 EXIT; LEAVE procedure name; 1. oracle: 如果exit語句在循環(huán)中就退出當(dāng)前循環(huán).如果exit語句不再循環(huán)中,就退出當(dāng)前過程或方法. 
   Mysql: 如果leave語句后面跟的是存儲過程名,則退出當(dāng)前存儲過程. 如果leave語句后面跟的是lable名. 則退出當(dāng)前l(fā)able. 
   
while 條件 loop
exit;
end loop;
label_name:while 條件 do
    leave label_name;
end while label_name;
4 定義游標(biāo) TYPE g_grp_cur IS REF CURSOR;
     
DECLARE cursor_name CURSOR FOR SELECT_statement; oracle可以先定義游標(biāo),然后給游標(biāo)賦值. 
mysql定義游標(biāo)時就需要給游標(biāo)賦值. Mysql定義游標(biāo)出自 Mysql 5.1 參考手冊20.2.11.1.聲明光標(biāo).
5 定義數(shù)組 TYPE unpacklist_type IS TABLE OF VARCHAR2(2000) INDEX BY BINARY_INTEGER; 可以使用臨時表代替oracle數(shù)組, 也可以循環(huán)拆分字符來替代oracle數(shù)組. 目前可以使用臨時表來代替oracle數(shù)組. 
詳見2009002-OTMPPS-Difficult Questions-0001.doc>>中2.4 Mysql數(shù)組處理部分
6 注釋方式不同  "-- message"  或 "/** ….  */" 或 "/* ….  */" "-- message"  或 "/* ….  */" 或 "#" mysql注釋來自  MySQL 5.1參考手冊 9.5. 注釋語法, 建議同oracle一樣, 單行用--, 多行/* */
7 自帶日期時間函數(shù)格式不同 Oracle時間格式:yyyy-MM-dd hh:mi:ss Mysql時間格式:%Y-%m-%d %H:%i:%s 1. MYSQL日期字段分DATE和TIME兩種. 
   ORACLE日期字段只有DATE,包含年月日時分秒信息. 
2. mysql中取當(dāng)前系統(tǒng)時間為now()函數(shù),精確到秒. 
   oracle中取當(dāng)前數(shù)據(jù)庫的系統(tǒng)時間為SYSDATE, 精確到秒.
8 日期加減 當(dāng)前時間加N天: sysdate+N
當(dāng)前時間減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函數(shù). 但Oracle的concat函數(shù)只能連接兩個字符串.
 Mysql使用concat方法連接字符串. MySQL的concat函數(shù)可以連接一個或者多個字符串,如
       mysql> select concat('10');   結(jié)果為: 10.
       mysql> select concat('11','22','33','aa'); 結(jié)果為: 112233aa
2. "||"在Mysql是與運(yùn)算
10 定義游標(biāo)不同 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游標(biāo)處理部分
11 事務(wù)回滾 ROLLBACK; ROLLBACK; oracle和mysql中使用方法相同
12 GOTO語句 GOTO check_date; GOTO check_date; oracle和mysql中使用方法相同

您可能感興趣的文章:
  • MySQL與Oracle 差異比較之七 其它
  • MySQL與Oracle 差異比較之七用戶權(quán)限
  • MySQL與Oracle 差異比較之六觸發(fā)器
  • MySQL與Oracle差異比較之五存儲過程&Function
  • MySQL與Oracle 差異比較之四條件循環(huán)語句
  • MySQL與Oracle差異比較之三 函數(shù)
  • MySQL與Oracle 差異比較之一數(shù)據(jù)類型
  • MySQL與Oracle SQL語言差異比較一覽

標(biāo)簽:威海 景德鎮(zhèn) 江蘇 瀘州 柳州 荊門 淮安 那曲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL與Oracle差異比較之二 基本語法》,本文關(guān)鍵詞  MySQL,與,Oracle,差異,比較,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL與Oracle差異比較之二 基本語法》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL與Oracle差異比較之二 基本語法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宁津县| 象山县| 固镇县| 德化县| 长顺县| 建始县| 临清市| 灵寿县| 库尔勒市| 文安县| 靖州| 麦盖提县| 宜昌市| 濮阳县| 平顺县| 武城县| 华坪县| 曲阳县| 邳州市| 浠水县| 怀集县| 海门市| 利川市| 神农架林区| 鄂尔多斯市| 宝兴县| 辉南县| 进贤县| 高唐县| 西充县| 盐津县| 吉水县| 北流市| 广安市| 岗巴县| 炎陵县| 南丰县| 苍山县| 苏尼特右旗| 庆安县| 吉首市|