溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL與Oracle的數(shù)據(jù)類(lèi)型有什么區(qū)別

發(fā)布時(shí)間:2021-07-19 14:57:38 來(lái)源:億速云 閱讀:280 作者:小新 欄目:數(shù)據(jù)庫(kù)

這篇文章主要為大家展示了“MySQL與Oracle的數(shù)據(jù)類(lèi)型有什么區(qū)別”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“MySQL與Oracle的數(shù)據(jù)類(lèi)型有什么區(qū)別”這篇文章吧。

數(shù)據(jù)類(lèi)型

編號(hào)ORACLEMYSQL注釋
1NUMBERint / DECIMALDECIMAL就是NUMBER(10,2)這樣的結(jié)構(gòu)INT就是是NUMBER(10),表示整型;
 MYSQL有很多類(lèi)int型,tinyint mediumint bigint等,不同的int寬度不一樣
2Varchar2(n)varchar(n) 
3DateDATATIME日期字段的處理
 MYSQL日期字段分DATE和TIME兩種,ORACLE日期字段只有DATE,包含年月日時(shí)分秒信息,用當(dāng)前數(shù)據(jù)庫(kù)的系統(tǒng)時(shí)間為 SYSDATE, 精確到秒,或者用字符串轉(zhuǎn)換成日期型函數(shù)TO_DATE(‘2001-08-01','YYYY-MM-DD')年-月-日 24小時(shí):分鐘:秒的格式Y(jié)YYY-MM-DD HH24:MI:SS TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.日期型字段轉(zhuǎn)換成字符串函數(shù)TO_CHAR(‘2001-08-01','YYYY-MM-DD HH24:MI:SS')
 
 日期字段的數(shù)學(xué)運(yùn)算公式有很大的不同。MYSQL找到離當(dāng)前時(shí)間7天用 DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)ORACLE找到離當(dāng)前時(shí)間7天用 DATE_FIELD_NAME >SYSDATE - 7;
 
 MYSQL中插入當(dāng)前時(shí)間的幾個(gè)函數(shù)是:NOW()函數(shù)以`'YYYY-MM-DD HH:MM:SS'返回當(dāng)前的日期時(shí)間,可以直接存到DATETIME字段中。CURDATE()以'YYYY-MM-DD'的格式返回今天的日期,可以直接存到DATE字段中。CURTIME()以'HH:MM:SS'的格式返回當(dāng)前的時(shí)間,可以直接存到TIME字段中。例:insert into tablename (fieldname) values (now())
 
 而oracle中當(dāng)前時(shí)間是sysdate
4INTEGERint / INTEGERMysql中INTEGER等價(jià)于int
5EXCEPTIONSQLEXCEPTION 詳見(jiàn)<<2009001-eService-O2MG.doc>>中2.5 Mysql異常處理
6CONSTANT VARCHAR2(1)mysql中沒(méi)有CONSTANT關(guān)鍵字從ORACLE遷移到MYSQL,所有CONSTANT常量只能定義成變量
7TYPE g_grp_cur IS REF CURSOR;光標(biāo) : mysql中有替代方案詳見(jiàn)<<2009001-eService-O2MG.doc>>中2.2 光標(biāo)處理
8TYPE unpacklist_type IS TABLE OF VARCHAR2(2000) INDEX BY BINARY_INTEGER;數(shù)組: mysql中借助臨時(shí)表處理
 或者直接寫(xiě)邏輯到相應(yīng)的代碼中,
 直接對(duì)集合中每個(gè)值進(jìn)行相應(yīng)的處理
詳見(jiàn)<<2009001-eService-O2MG.doc>>中2.4 數(shù)組處理
9自動(dòng)增長(zhǎng)的序列自動(dòng)增長(zhǎng)的數(shù)據(jù)類(lèi)型MYSQL有自動(dòng)增長(zhǎng)的數(shù)據(jù)類(lèi)型,插入記錄時(shí)不用操作此字段,會(huì)自動(dòng)獲得數(shù)據(jù)值。ORACLE沒(méi)有自動(dòng)增長(zhǎng)的數(shù)據(jù)類(lèi)型,需要建立一個(gè)自動(dòng)增長(zhǎng)的序列號(hào),插入記錄時(shí)要把序列號(hào)的下一個(gè)值賦于此字段。
10NULLNULL空字符的處理
 MYSQL的非空字段也有空的內(nèi)容,ORACLE里定義了非空字段就不容許有空的內(nèi)容。按MYSQL的NOT NULL來(lái)定義ORACLE表結(jié)構(gòu), 導(dǎo)數(shù)據(jù)的時(shí)候會(huì)產(chǎn)生錯(cuò)誤。因此導(dǎo)數(shù)據(jù)時(shí)要對(duì)空字符進(jìn)行判斷,如果為NULL或空字符,需要把它改成一個(gè)空格的字符串。

以上是“MySQL與Oracle的數(shù)據(jù)類(lèi)型有什么區(qū)別”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI