好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL與Oracle數據類型對應關系(表格形式)

MySQL與Oracle數據類型對應關系(表格形式)

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

MySQL與Oracle兩種數據庫在工作中,都是用的比較多的數據庫,由于MySQL與Oracle在數據類型上有部分差異,在我們遷移數據庫時,會遇上一定的麻煩,下面介紹MySQL與Oracle數據庫數據類型的對應關系。

一、常見數據類型在MySQL與Oracle數據庫中的表現形式

說明

mysql

oracle

變長字符串

VARCHAR[0-65535]

定義長度默認按字符長度計算,如果是GBK編碼的漢字將占用2個字節

VARCHAR2[1-4000]
VARCHAR是VARCHAR2的同義詞

定義默認按字節長度計算

整數

TINYINT(-128-127)

SMALLINT(-32768-32767)

MEDIUMINT(-8388608-8388607)

INT(-2147483648-2147483647)
BIGINT(-9223372036854775808-9223372036854775807) 

無專用類型,

TINYINT可以用NUMBER(3,0)代替

SMALLINT可以用NUMBER(5,0)代替

MEDUIMINT可以用NUMBER(7,0)代替
 

INT可以用NUMBER(10,0)代替
 

BIGINT可以用NUMBER(20,0)代替


 

ORACLE中有SMALLINT,INT,INTEGER類型,不過這是NUMBER(38,0)的同義詞

數值類型

DECIMAL[1-65[,0-30]]
NUMERIC是DECIMAL的同義詞

NUMBER 可表示數范圍: 1*10^-130至1*10^126

NUMBER([1-38][,-84-127])

 

DECIMAL、NUMERIC、DEC是NUMBER的同義詞

浮點型

FLOAT(D,M)

oracle10g開始增加BINARY_FLOAT類型

10g以前無專用類型,可以用NUMBER代替

ORACLE中有FLOAT和REAL類型,不過這是NUMBER的同義詞

雙精度浮點型

DOUBLE(D,M)

oracle10g開始增加BINARY_DOUBLE類型

10g以前無專用類型,可以用NUMBER代替

ORACLE中有DOUBLE PRECISION類型,不過這是NUMBER的同義詞

位類型

BIT(1-64)

日期類型

DATE,3字節存儲,只存儲日期,沒有時間,支持范圍是[1000-01-01]至[9999-12-31]
TIME,3字節存儲,只存儲時間,沒有日期,支持范圍是[-838:59:59]至[838:59:59]
DATETIME,占8字節存儲,可表示日期和時間,支持范圍是[1000-01-01 00:00:00]至[9999-12-31 23:59:59]
TIMESTAMP,占4字節存儲,可表示日期和時間,范圍是[1970-01-01 00:00:00]至[2038-01-19 03:14:07]

DATE類型
7字節存儲,可表示日期和時間,支持范圍是[-4712-01-01 00:00:00]至[9999-12-31 23:59:59]

高精度日期

5.6.4以前不支持小數秒精度
5.6.4開始TIME,DATETIME,TIMESTAMP支持,最多可以6位小數秒,也就是微秒級別

TIMESTAMP[0-9]
占用空間7-11個字節,當小數秒精度為0時與DATE類型相同,小數秒最高精度可達9位,也就是納精度

年份

YEAR,1字節存儲,只存儲年份,支持范圍是[1901]至[2155]

無對應類型,可以用NUMBER(3,0)代替

定長字符串

CHAR[0-255],定義長度默認按字符長度計算,最大保存255字符

CHAR[1-2000]

定義默認按字節長度計算

無符號說明

支持,用于數值類型

不支持

大字符串,一般用于存儲文本文件或超大描述及備注類信息

TINYTEXT 最大支持255個字節
TEXT最大支持65535個字節
MEDIUMTEXT最大支持16MB個字節
LONGTEXT最大支持4GB字節

字段不支持默認值

支持(CLOB)
oracle10g以前最大支持4GB個字節

oracle10g開始最大支持4GB個數據塊,數據塊大小為2KB-32KB

oracle還有一個LONG類型,是早期的存儲大字符串類型,最大支持2GB字節,現已不推薦使用

二進制對象,一般用于存儲文件或圖片數據

TINYBLOB 最大支持255個字節
BLOB最大支持65535個字節
MEDIUMBLOB最大支持16MB個字節

LONGBLOB最大支持4GB字節

 

字段不支持默認值

支持(BLOB)

oracle10g以前最大支持4GB個字節
 

oracle10g開始最大支持4G個數據塊,數據塊大小為2KB-32KB

oracle還有一個LONG RAW類型,是早期的存儲二進制類型,最大支持2GB字節,現已不推薦使用

二進制信息

BINARY(0-255),定長
VARBINARY(0-65535),變長

RAW(1-2000)

枚舉類型

ENUM(v1,v2,v3,...),最多65535個元素

不支持

集合類型

SET(v1,v2,v3,...),最多64個元素

不支持

國際化字符集類型,較少使用

無,MYSQL可以對每個字段指定字符編碼

支持
NCHAR(1-2000)
NVARCHAR(1-4000)
NCLOB

外部文件指針類型

不支持

支持
文件大小最大4GB
文件名稱最長255字符

 

不支持

支持

 

不支持

支持

自動增長類型

支持
使用簡單

不支持
一般使用SEQUENCE解決,用法與自增類型差別較大,使用較復雜,但能實現非常靈活的應用,包括字符自增主鍵、全局主鍵等等

 

不支持函數和表達式
TEXT和BLOB字段類型不支持默認值

支持函數和表達式

 

支持,例如,把emp表的id字段順序放在name字段后面:
alter table emp modify column id varchar(20) after name;

不支持,只能重建表或字段

虛擬字段是一個邏輯字段定義,其結果值通常是一個表達式,并在表中存儲物理值,不占用空間,主要用于簡化查詢邏輯。比如有一個商品銷售表有單價和數量兩個字段,那可以建一個虛擬字段金額,其表達式=單價*數量

不支持

11g支持,例:
create table sales
(
  id       number,
  quantity number,
  price    number,
  amount   GENERATED always as (quantity*price) virtual
);

 

INNODB 最大1000個字段
所有字段總定義長度不能超過65535字節
所有固定長度字段的總長度不超過半個數據塊大小(數據塊大小一般為16K)

最大1000個字段

二、MySQL與Oracle數據庫常見數據類型對應關系

編號 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 空字符的處理
MYSQL的非空字段也有空的內容,ORACLE里定義了非空字段就不容許有空的內容。按MYSQL的NOT NULL來定義ORACLE表結構, 導數據的時候會產生錯誤。因此導數據時要對空字符進行判斷,如果為NULL或空字符,需要把它改成一個空格的字符串。

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語句在循環中就退出當前循環.如果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中使用方法相同

以上就是MySQL與Oracle數據類型對應關系的全部內容了

您可能感興趣的文章:
  • MySQL外鍵約束的實例講解
  • 詳解MySQL 外鍵約束
  • MySQL外鍵約束常見操作方法示例【查看、添加、修改、刪除】
  • MySQL刪除有外鍵約束的表數據方法介紹
  • MySQL刪除表的時候忽略外鍵約束的簡單實現
  • MySQL 關閉子表的外鍵約束檢察方法
  • MySQL外鍵約束的禁用與啟用命令
  • 詳解MySQL中的外鍵約束問題
  • MySQL創建數據表并建立主外鍵關系詳解
  • MySQL 外鍵約束和表關系相關總結

標簽:那曲 瀘州 柳州 淮安 江蘇 景德鎮 威海 荊門

巨人網絡通訊聲明:本文標題《MySQL與Oracle數據類型對應關系(表格形式)》,本文關鍵詞  MySQL,與,Oracle,數據,類型,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL與Oracle數據類型對應關系(表格形式)》相關的同類信息!
  • 本頁收集關于MySQL與Oracle數據類型對應關系(表格形式)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 啊老板换个地方做gif动态图| 久久夜色精品亚洲AV三区青椒 | 被夫上司持续侵犯7天7夜| 韩国大尺度《偷欢2》| 91免费短视频| 日韩欧美综合在线二区三区| 十二寡妇肉床艳史K8影院| 嫩模艾xx疯狂5视频播放| 把腿扒开让我添个痛快动图| 欧美日韩黄色片| 8x8ⅹ拔擦拔擦在线播放| 第一次破苞播放| 亚洲综合国产一区在线| 国产极品大乳在线观看 | 放荡的情妇| 拼多多拼小圈在哪| 美女的胸隐私免费观看| 亚洲va欧洲va欧美va在线观看| 国产高清无密码一区二区三区 | 成人性动漫免费视频| 狂野小农民无删减版完整视频| 装睡被陌生人摸出水| 又粗又硬又长太猛太爽受不了| mm131美女久久精品美女图片| 91视频免费观看高清观看完整| 宁德市| 男人与雌性宠物交| 夜夜爱夜夜做| 黄色a级片视频| 91色噜噜狠狠色婷婷绿巨人| 一边吃奶一边做边爱完整版| 高冷女警被辱高h系列| 中年熟妇的大肥唇熟女影视| 高清三级特黄60分钟在线播放| 欧美成人511性影院视频社区| 老头玩小嫩奶视频在线观看| 久久精品国产99国产精2018| 免费特黄| 徐闻县| 免费看成人A片无码的直播APP| 教授和自己的学生|