oracle存儲引擎
❶ mysql和oracle的區別
MySQL與Oracle的區別:
一、Oracle是大型資料庫而Mysql是中小型資料庫,Oracle市場佔有率達40%,Mysql只有20%左右,同時Mysql是開源的而Oracle價格非常高。
二、Oracle支持大並發,大訪問量,是OLTP最好的工具。
三、安裝所用的空間差別也是很大的,Mysql安裝完後才152M而Oracle有3G左右,且使用的時候Oracle佔用特別大的內存空間和其他機器性能。
四、Oracle也Mysql操作上的一些區別:
1、主鍵Mysql一般使用自動增長類型,在創建表時只要指定表的主鍵為autoincrement,插入記錄時,不需要再指定該記錄的主鍵值,Mysql將自動增長;Oracle沒有自動增長類型,主鍵一般使用的序列,插入記錄時將序列號的下一個值付給該欄位即可;只是ORM框架是只要是native主鍵生成策略即可。
2、單引號的處理MYSQL里可以用雙引號包起字元串,ORACLE里只可以用單引號包起字元串。在插入和修改字元串前必須做單引號的替換:把所有出現的一個單引號替換成兩個單引號。
3、翻頁的SQL語句的處理MYSQL處理翻頁的SQL語句比較簡單,用LIMIT開始位置,記錄個數;ORACLE處理翻頁的SQL語句就比較繁瑣了。每個結果集只有一個ROWNUM欄位標明它的位置,並且只能用ROWNUM<100,不能用ROWNUM>80。
4、長字元串的處理長字元串的處理ORACLE也有它特殊的地方。INSERT和UPDATE時最大可操作的字元串長度小於等於4000個單位元組,如果要插入更長的字元串,請考慮欄位用CLOB類型,方法借用ORACLE里自帶的DBMS_LOB程序包。插入修改記錄前一定要做進行非空和長度判斷,不能為空的欄位值和超出長度欄位值都應該提出警告,返回上次操作。
5、空字元的處理MYSQL的非空欄位也有空的內容,ORACLE里定義了非空欄位就不容許有空的內容。按MYSQL的NOTNULL來定義ORACLE表結構,導數據的時候會產生錯誤。因此導數據時要對空字元進行判斷,如果為NULL或空字元,需要把它改成一個空格的字元串。
6、字元串的模糊比較MYSQL里用欄位名like'%字元串%',ORACLE里也可以用欄位名like'%字元串%'但這種方法不能使用索引,速度不快。
7、Oracle實現了ANSIISQL中大部分功能,如,事務的隔離級別、傳播特性等而Mysql在這方面還是比較的弱。
❷ 請問下mysql和oracle的區別
請問下mysql和oracle的區別:
1、價格
價格是兩個資料庫之間最顯著的差異。Oracle有一個名為Oracle Express Edition的東西,這個版本完全免費。不幸的是,該版本對這些功能有太多限制。如果你繼續購買全功能標准版或企業版,它將花費你數萬美元。另一方面,MySQL是一個開源資料庫,完全免費。最著名的Facebook社交網站運行在MySQL上。
2、安全
雖然MySQL使用三個參數來驗證用戶,即用戶名,密碼和位置,但Oracle使用了許多安全功能,如用戶名,密碼,配置文件,本地身份驗證,外部身份驗證,高級安全增強功能等。
3、對象名稱
雖然某些模式對象名稱在Oracle和MySQL中都不區分大小寫,例如列,存儲過程,索引等,但在某些情況下,兩個資料庫之間的區分大小寫不同;Oracle對所有對象名稱都不區分大小寫,但是,與Oracle不同,某些MySQL對象名稱(如資料庫和表)區分大小寫(取決於底層操作系統)。
4、字元數據類型
兩個資料庫中支持的字元類型存在一些差異。MySQL為字元類型提供CHAR和VARCHAR,最大長度允許為65,535位元組(CHAR最多可以為255位元組,VARCHAR為65.535位元組)。另一方面,Oracle支持四種字元類型,即CHAR,NCHAR,VARCHAR2和NVARCHAR2;所有四種字元類型都需要至少1個位元組長;CHAR和NCHAR最大可以是2000個位元組,NVARCHAR2和VARCHAR2的最大限制是4000個位元組。可能會在最新版本中進行擴展。
❸ mysql資料庫和oracle資料庫的區別
1、體積不同。
Oracle它體積比較龐大,一般是用來開發大型應用(例如分布式)的。而MySQL的體積相對來說比較小,較之Oracle更容易安裝、維護以及管理,操作也簡單,最重要的是它是三個中唯一一個開源資料庫,但目前也屬於Oracle公司的產品了。
2、容量不同。
Oracle容量無限,根據配置決定;而MySQL使用MyISAM存儲引擎,最大表尺寸為65536TB。 MySQL資料庫的最大有效表尺寸通常是由操作系統對文件大小的限制決定的,而不是由MySQL內部限制決定。
3、平台支持及速度的區別。
Oracle支持大多數平台;而MySQL支持各種平台,適合linux。至於速度,Oracle在Linux下的性能,在少量數據時速度低於MySQL,在千萬級時速度快於MySQL。
4、資料庫崩潰造成的影響不同。
Oracle資料庫崩潰後恢復很麻煩,因為他把很多東西放在內存里;資料庫連接要慢些,最好用連接池;而MySQL使用預設的IP埠,但是有時候這些IP也會被一些黑客闖入,使用MyISAM配置,不慎損壞資料庫,結果可能會導致所有的數據丟失。
5、性能的區別。
Oracle全面,完整,穩定,但一般數據量大,對硬體要求較高 ;而MySQL使用CPU和內存極少,性能很高,但擴展性較差。
6、授權價格區別。
Oracle價格較貴,例如Oracle 10G/11G 標准版 [10用戶]¥25600 ,Oracle 10G/11G 標准版 [1CPU無限用戶] ¥157600。而MySQL採用雙重授權,他們是GPL和MySQLAB制定的商業許可協議。如果你在一個遵循GPL的自由項目中使用 MySQL,那麼你可以遵循GPL協議免費使用MySQL。否則,你需要購買MySQLAB制定的那個商業許可協議。
❹ oracle和mysql的區別
這個沒什麼區別的,只是價錢的區別的,
❺ 請問MSSQL,ORACLE,資料庫引擎是什麼
各類資料庫管理系統的設計都有其獨特之處。在Oracle上也是有存儲引擎的,但Oracle官方從來都不這么提,只說存儲架構。按功能上來看,InnoDB在設計之初參考了Oracle的設計(如表空間,extent,塊等)。MSSQL -- 不知道。
❻ mysql和oracle之間有什麼區別
一、並發性
並發性是oltp資料庫最重要的特性,但並發涉及到資源的獲取、共享與鎖定。
mysql:
mysql以表級鎖為主,對資源鎖定的粒度很大,如果一個session對一個表加鎖時間過長,會讓其他session無法更新此表中的數據。
oracle:
oracle使用行級鎖,對資源鎖定的粒度要小很多,只是鎖定sql需要的資源,所以oracle對並發性的支持要好很多。
二、一致性
oracle:
oracle支持serializable的隔離級別,可以實現最高級別的讀一致性。每個session提交後其他session才能看到提交的更改。
mysql:
mysql沒有類似oracle的構造多版本數據塊的機制,只支持read commited的隔離級別。一個session讀取數據時,其他session不能更改數據,但可以在表最後插入數據。
session更新數據時,要加上排它鎖,其他session無法訪問數據。
三、事務
oracle很早就完全支持事務。
mysql在innodb存儲引擎的行級鎖的情況下才支持事務。
四、數據持久性
oracle
保證提交的數據均可恢復,因為oracle把提交的sql操作線寫入了在線聯機日誌文件中,保持到了磁碟上,
如果出現資料庫或主機異常重啟,重啟後oracle可以考聯機在線日誌恢復客戶提交的數據。
mysql:
默認提交sql語句,但如果更新過程中出現db或主機重啟的問題,也許會丟失數據。
五、提交方式
oracle默認不自動提交,需要用戶手動提交。
mysql默認是自動提交。
六、邏輯備份
oracle邏輯備份時不鎖定數據,且備份的數據是一致的。
mysql邏輯備份時要鎖定數據,才能保證備份的數據是一致的,影響業務正常的dml使用。
七、熱備份
oracle有成熟的熱備工具rman,熱備時,不影響用戶使用資料庫。即使備份的資料庫不一致,也可以在恢復時通過歸檔日誌和聯機重做日誌進行一致的回復。
mysql:
myisam的引擎,用mysql自帶的mysqlhost熱備時,需要給表加讀鎖,影響dml操作。
八、sql語句的擴展和靈活性
mysql對sql語句有很多非常實用而方便的擴展,比如limit功能,insert可以一次插入多行數據,select某些管理數據可以不加from。
oracle在這方面感覺更加穩重傳統一些。
❼ oracle性能的一些問題,在非常單純的情況下,會比mysql快多少
mysql的速度並不比orcale慢,問題在於你會不會優化MYSQL的語句。 不要說三千萬,如果優化爛,就算只有10萬條記錄,oracle一樣慢的讓你頭疼。 此外如果你不明白什麼叫做存儲引擎,不明白各大存儲引擎的優勢與弱勢,不明白根據你的具體應用來選擇合適的存儲引擎,不懂得針對各大存儲引擎優化你的SQL語句,不懂得如何使用預解析語句,不明白存儲過程的原理,不了解資料庫的優化器是怎樣工作的,不了解資料庫的整個運作流程。 那麼對你來說,不管MYSQL,還是orcale還是什麼資料庫,都是一樣的,都不會有什麼太大的區別。
❽ oracle 刷新臟頁如何優化
當要讀入的數據頁沒有在內存的時候,就必須到緩沖池中申請一個數據頁。這時候只能把最久不使用的數據頁從內存中淘汰掉:如果要淘汰的是一個干凈頁,就直接釋放出來復用;但如果是臟頁呢,就必須將臟頁先刷到磁碟,變成干凈頁後才能復用。
InnoDB存儲引擎還提供了Flush Neighbor Page(刷新鄰接頁)的特性。其工作原理為:當刷新一個臟頁時,InnoDB存儲引擎會檢測該頁所在區(extent)的所有頁,如果是臟頁,那麼一起進行刷新。InnoDB1.2.x版本開始提供了參數innodb_flush_neighbors,用來控制是否啟用該特性。
❾ oracle和mysql區別
oracle和mysql區別:
1、體積不同。oracle是oracle的資料庫產品,它體積比較龐大,一般是用來開發大型應用(例如分布式)的。而mysql的體積相對來說比較小,較之oracle更容易安裝、維護以及管理,操作也簡單,最重要的是它是三個中唯一一個開源資料庫,但目前也屬於Oracle公司的產品了。
2、容量不同。Oracle容量無限,根據配置決定;而mysql使用MyISAM存儲引擎,最大表尺寸為65536TB。MySQL資料庫的最大有效表尺寸通常是由操作系統對文件大小的限制決定的,而不是由MySQL內部限制決定。
3、平台支持及速度的區別。Oracle支持大對數平台;而mysql支持各種平台,適合Linux。至於速度,oracle在linux下的性能,在少量數據時速度低於mysql,在千萬級時速度快於Mysql。
4、資料庫崩潰造成的影響不同。oracle資料庫崩潰後恢復很麻煩,因為他把很多東西放在內存里;資料庫連接要慢些,最好用連接池;而mysql使用預設的ip埠,但是有時候這些ip也會被一些黑客闖入,使用myisam配置,不慎損壞資料庫,結果可能會導致所有的數據丟失。
5、性能的區別。Oracle全面,完整,穩定,但一般數據量大,對硬體要求較高;而mysql使用CPU和內存極少,性能很高,但擴展性較差。
6、授權價格區別。Oracle價格較貴,例如Oracle10G//11G標准版[10用戶]¥25600,Oracle10G//11G標准版[1CPU無限用戶]¥157600。而MySQL採用雙重授權,他們是GPL和MySQLAB制定的商業許可協議。如果你在一個遵循GPL的自由項目中使用MySQL,那麼你可以遵循GPL協議免費使用MySQL。否則,你需要購買MySQLAB制定的那個商業許可協議。