欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle 和 mysql的9點(diǎn)區(qū)別

 更新時(shí)間:2014年04月10日 14:27:42   作者:  
這篇文章主要介紹了Oracle 和 mysql的9點(diǎn)區(qū)別,需要的朋友可以參考下

1.組函數(shù)用法規(guī)則

mysql中組函數(shù)在select語句中可以隨意使用,但在oracle中如果查詢語句中有組函數(shù),那其他列名必須是組函數(shù)處理過的,或者是group by子句中的列否則報(bào)錯(cuò)
eg:select name,count(money) from user;這個(gè)放在mysql中沒有問題在oracle中就有問題了

2.自動增長的數(shù)據(jù)類型處理

MYSQL有自動增長的數(shù)據(jù)類型,插入記錄時(shí)不用操作此字段,會自動獲得數(shù)據(jù)值。ORACLE沒有自動增長的數(shù)據(jù)類型,需要建立一個(gè)自動增長的序列號,插入記錄時(shí)要把序列號的下一個(gè)值賦于此字段。
CREATE SEQUENCE序列號的名稱(最好是表名+序列號標(biāo)記)INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的長度來定,如果定義的自動增長的序列號NUMBER(6),最大值為999999
INSERT語句插入這個(gè)字段值為:序列號的名稱.NEXTVAL

3.單引號的處理

MYSQL里可以用雙引號包起字符串,ORACLE里只可以用單引號包起字符串。在插入和修改字符串前必須做單引號的替換:把所有出現(xiàn)的一個(gè)單引號替換成兩個(gè)單引號。

4.翻頁的SQL語句的處理

MYSQL處理翻頁的SQL語句比較簡單,用LIMIT開始位置,記錄個(gè)數(shù);PHP里還可以用SEEK定位到結(jié)果集的位置。ORACLE處理翻頁的SQL語句就比較繁瑣了。每個(gè)結(jié)果集只有一個(gè)ROWNUM字段標(biāo)明它的位置,并且只能用ROWNUM<100,不能用ROWNUM>80。
以下是經(jīng)過分析后較好的兩種ORACLE翻頁SQL語句(ID是唯一關(guān)鍵字的字段名):
語句一:
SELECT ID, [FIELD_NAME,...] FROM TABLE_NAME WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 條件1 ORDER BY 條件2) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 條件3;
語句二:
SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,...] FROM TABLE_NAME WHERE 條件1 ORDER BY 條件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 條件3;

5.長字符串的處理

長字符串的處理ORACLE也有它特殊的地方。INSERT和UPDATE時(shí)最大可操作的字符串長度小于等于4000個(gè)單字節(jié),如果要插入更長的字符串,請考慮字段用CLOB類型,方法借用ORACLE里自帶的DBMS_LOB程序包。插入修改記錄前一定要做進(jìn)行非空和長度判斷,不能為空的字段值和超出長度字段值都應(yīng)該提出警告,返回上次操作。

6.日期字段的處理

MYSQL日期字段分DATE和TIME兩種,ORACLE日期字段只有DATE,包含年月日時(shí)分秒信息,用當(dāng)前數(shù)據(jù)庫的系統(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

7.空字符的處理

MYSQL的非空字段也有空的內(nèi)容,ORACLE里定義了非空字段就不容許有空的內(nèi)容。按MYSQL的NOT NULL來定義ORACLE表結(jié)構(gòu),導(dǎo)數(shù)據(jù)的時(shí)候會產(chǎn)生錯(cuò)誤。因此導(dǎo)數(shù)據(jù)時(shí)要對空字符進(jìn)行判斷,如果為NULL或空字符,需要把它改成一個(gè)空格的字符串

8.字符串的模糊比較

MYSQL里用字段名like%‘字符串%',ORACLE里也可以用字段名like%‘字符串%'但這種方法不能使用索引,速度不快,用字符串比較函數(shù)instr(字段名,‘字符串')>0會得到更精確的查找結(jié)果。

9.程序和函數(shù)里,操作數(shù)據(jù)庫的工作完成后請注意結(jié)果集和指針的釋放。

相關(guān)文章

  • mysql數(shù)據(jù)庫隔離級別詳解

    mysql數(shù)據(jù)庫隔離級別詳解

    SQL標(biāo)準(zhǔn)定義了4類隔離級別,包括了一些具體規(guī)則,用來限定事務(wù)內(nèi)外的哪些改變是可見的,哪些是不可見的,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫隔離級別的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • 解析mysql與Oracle update的區(qū)別

    解析mysql與Oracle update的區(qū)別

    本篇文章是對mysql與Oracle update的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-07-07
  • mysql insert if not exists防止插入重復(fù)記錄的方法

    mysql insert if not exists防止插入重復(fù)記錄的方法

    在 MySQL 中,插入(insert)一條記錄很簡單,但是一些特殊應(yīng)用,在插入記錄前,需要檢查這條記錄是否已經(jīng)存在,只有當(dāng)記錄不存在時(shí)才執(zhí)行插入操作,本文介紹的就是這個(gè)問題的解決方案。
    2011-04-04
  • Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析

    Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析

    這篇文章主要介紹了Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • MySQL中列轉(zhuǎn)行和行轉(zhuǎn)列總結(jié)解決思路

    MySQL中列轉(zhuǎn)行和行轉(zhuǎn)列總結(jié)解決思路

    最近工作中用到了好幾次列轉(zhuǎn)行,索性做個(gè)小總結(jié),下面這篇文章主要給大家介紹了關(guān)于MYSQL如何列轉(zhuǎn)行的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • Mysql存儲引擎特性總結(jié)

    Mysql存儲引擎特性總結(jié)

    這篇文章主要介紹了Mysql存儲引擎特性總結(jié),同時(shí)總結(jié)了最常用的2種存儲引擎的特性,以及各引擎的適用環(huán)境,需要的朋友可以參考下
    2014-07-07
  • Mysql應(yīng)用安裝后找不到my.ini文件的解決過程

    Mysql應(yīng)用安裝后找不到my.ini文件的解決過程

    剛剛在修改mysql默認(rèn)配置的時(shí)候,發(fā)現(xiàn)找不到my.ini文件,下面這篇文章主要給大家介紹了關(guān)于Mysql應(yīng)用安裝后找不到my.ini文件的解決過程,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • MySQL安裝配置以及安裝失敗解決過程

    MySQL安裝配置以及安裝失敗解決過程

    我們在下載完MYSQL時(shí),安裝可能會遇到或大或小的問題,下面這篇文章主要給大家介紹了關(guān)于MySQL安裝配置以及安裝失敗解決的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • MySQL存儲時(shí)間類型選擇的問題講解

    MySQL存儲時(shí)間類型選擇的問題講解

    今天小編就為大家分享一篇關(guān)于MySQL存儲時(shí)間類型選擇的問題講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • MySQL 自定義變量的概念及特點(diǎn)

    MySQL 自定義變量的概念及特點(diǎn)

    MySQL 是可以自定義臨時(shí)變量的,而臨時(shí)變量在做查詢優(yōu)化和靜態(tài)查詢分析時(shí)十分有用。而實(shí)際上很少有人記得 MySQL 的自定義變量。本篇文章講述 MySQL 的自定義變量的概念及特點(diǎn)。
    2021-05-05

最新評論