MySQL與Oracle 差異比較之一資料類型,mysqloracle
資料類型
編號 |
ORACLE |
MYSQL |
注釋 |
1 |
NUMBER |
int / DECIMAL |
DECIMAL就是NUMBER(10,2)這樣的結構INT就是是NUMBER(10),表示整型; MYSQL有很多類int型,tinyint mediumint bigint等,不同的int寬度不一樣 |
2 |
Varchar2(n) |
varchar(n) |
|
3 |
Date |
DATATIME |
日期欄位的處理 MYSQL日期欄位分DATE和TIME兩種,ORACLE日期欄位只有DATE,包含年月日時分秒資訊,用當前資料庫的系統時間為 SYSDATE, 精確到秒,或者用字串轉換成日期型函數TO_DATE(‘2001-08-01','YYYY-MM-DD')年-月-日 24小時:分鐘:秒的格式YYYY-MM-DD HH24:MI:SS TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.日期型欄位轉換成字串函數TO_CHAR(‘2001-08-01','YYYY-MM-DD HH24:MI:SS') 日期欄位的數學運算公式有很大的不同。MYSQL找到離目前時間7天用 DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)ORACLE找到離目前時間7天用 DATE_FIELD_NAME >SYSDATE - 7; MYSQL中插入目前時間的幾個函數是:NOW()函數以`'YYYY-MM-DD HH:MM:SS'返回當前的日期時間,可以直接存到DATETIME欄位中。CURDATE()以'YYYY-MM-DD'的格式返回今天的日期,可以直接存到DATE欄位中。CURTIME()以'HH:MM:SS'的格式返回當前的時間,可以直接存到TIME欄位中。例:insert into tablename (fieldname) values (now()) 而oracle中目前時間是sysdate |
4 |
INTEGER |
int / INTEGER |
Mysql中INTEGER等價於int |
5 |
EXCEPTION |
SQLEXCEPTION |
詳見<<2009001-eService-O2MG.doc>>中2.5 Mysql異常處理 |
6 |
CONSTANT VARCHAR2(1) |
mysql中沒有CONSTANT關鍵字 |
從ORACLE遷移到MYSQL,所有CONSTANT常量只能定義成變數 |
7 |
TYPE g_grp_cur IS REF CURSOR; |
游標 : mysql中有替代方案 |
詳見<<2009001-eService-O2MG.doc>>中2.2 游標處理 |
8 |
TYPE unpacklist_type IS TABLE OF VARCHAR2(2000) INDEX BY BINARY_INTEGER; |
數組: mysql中藉助暫存資料表處理 或者直接寫邏輯到相應的代碼中, 直接對集合中每個值進行相應的處理 |
詳見<<2009001-eService-O2MG.doc>>中2.4 數組處理 |
9 |
自動成長的序列 |
自動成長的資料類型 |
MYSQL有自動成長的資料類型,插入記錄時不用操作此欄位,會自動獲得資料值。ORACLE沒有自動成長的資料類型,需要建立一個自動成長的序號,插入記錄時要把序號的下一個值賦於此欄位。 |
10 |
NULL |
NULL |
Null 字元的處理 MYSQL的非空欄位也有空的內容,ORACLE裡定義了非空欄位就不容許有空的內容。按MYSQL的NOT NULL來定義ORACLE表結構, 導資料的時候會產生錯誤。因此導資料時要對Null 字元進行判斷,如果為NULL或Null 字元,需要把它改成一個空格的字串。 |