MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理
各版本的一些命令差異:
show innodb status\G mysql-5.1 show engines innodb status\G mysql-5.5
關(guān)于grant授權(quán) mysql-5.5 的 user@'%' 不包含localhost
-----------------------------------------------------------------------
MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別
1、4.1 增加了子查詢的支持,字符集增加UTF-8,GROUP BY語(yǔ)句增加了ROLLUP,mysql.user表采用了更好的加密算法。
2、5.0 增加了Stored procedures、Views、Cursors、Triggers、XA transactions的支持,增加了INFORATION_SCHEMA系統(tǒng)數(shù)據(jù)庫(kù)。
3、5.1 增加了Event scheduler,Partitioning,Pluggable storage engine API ,Row-based replication、Global級(jí)別動(dòng)態(tài)修改general query log和slow query log的支持。
4、5.5的新特征
1)默認(rèn)存儲(chǔ)引擎更改為InnoDB
2)提高性能和可擴(kuò)展性
a. 提高了默認(rèn)線程并發(fā)數(shù)(innodb_thread_concurrency)
b. 后臺(tái)輸入/輸出線程控制(innodb_read_io_threads、innodb_write_io_threads)
c. 主線程輸入/輸出速率控制(innodb_io_capacity)
d. 操作系統(tǒng)內(nèi)存分配程序使用控制(innodb_use_sys_malloc)
e. 適應(yīng)性散列索引(Hash Index)控制,用戶可以關(guān)閉適應(yīng)性散列功能。
f. 插入緩沖(Insert Buffering)控制,用戶可以關(guān)閉innodb的插入緩沖功能。
g. 通過(guò)快速加鎖算法提高可擴(kuò)展性,innodb不在使用代理(posix)線程,而是使用原生的獨(dú)立操作來(lái)完成互斥和讀寫鎖定。
h. 恢復(fù)組提交(Restored Group Commit)
i. 提高恢復(fù)性能
j. 多緩沖池實(shí)例
k. 多個(gè)回滾段(Multiple Rollback Segments),之前的innodb版本最大能處理1023個(gè)并發(fā)處理操作,現(xiàn)在mysql5.5可以處理高達(dá)128K的并發(fā)事物,
l. Linux系統(tǒng)固有的異步輸入/輸出,mysql5.5數(shù)據(jù)庫(kù)系統(tǒng)也提高了linux系統(tǒng)的輸入輸出請(qǐng)求的并發(fā)數(shù)。
m. 擴(kuò)展變化緩沖:添加了刪除緩沖和清除緩沖
n. 改善了日志系統(tǒng)互斥和單獨(dú)刷新(Flush)列表互斥
o. 改善清除程序進(jìn)度,在mysql5.5中清楚操作線程是獨(dú)立的線程,并支持并發(fā),可以使用innodb_purge_treads配置。
p. 改善事務(wù)處理中的元數(shù)據(jù)鎖定。例如,事物中一個(gè)語(yǔ)句需要鎖一個(gè)表,會(huì)在事物結(jié)束時(shí)釋放這個(gè)表,而不是像以前在語(yǔ)句結(jié)束時(shí)釋放表。
3)提高實(shí)用性
a. 半同步復(fù)制(Semi-synchronous Replication)
b. 復(fù)制Heartbeat
c. 中繼日志自動(dòng)恢復(fù)(Automatic Relay Log Recovery)
d. 根據(jù)服務(wù)器過(guò)濾項(xiàng)復(fù)制(Replication Per Server Filtering)
e. 從服務(wù)器復(fù)制支持的數(shù)據(jù)類型轉(zhuǎn)換(Replication Slave Side Data Type Conversions)
4)提高易管理性和效率
a. 建立快速索引(Faster Index Creation)
b. 高效的數(shù)據(jù)壓縮(Efficient Data Compression)
c. 為大物件和可變長(zhǎng)度列提供高效存儲(chǔ)
d. 增加了INFORMATION_SCHEMA表,新的表提供了與InnoDB壓縮和事務(wù)處理鎖定有關(guān)的具體信息。
5)提高可用性
a. 針對(duì)SIGNAL/RESIGNAL的新SQL語(yǔ)法
b. 新的表/索引分區(qū)選項(xiàng)。MySQL5.5將表和索引RANG和LIST分區(qū)范圍擴(kuò)展到了非整數(shù)列和日期,并增加了在多個(gè)列上分區(qū)的能力。
6)改善檢測(cè)和診斷
Mysql5.5引入了一種新的性能架構(gòu)(performancn_shema,P_S),用于監(jiān)控mysql監(jiān)控服務(wù)器運(yùn)行時(shí)的性能。
5、5.6的新特征
1)InnoDB現(xiàn)在可以限制大量表打開(kāi)的時(shí)候內(nèi)存占用過(guò)多的問(wèn)題(比如這里提到的)(第三方已有補(bǔ)丁)
2)InnoDB性能加強(qiáng)。如分拆kernel mutex;flush操作從主線程分離;多個(gè)perge線程;大內(nèi)存優(yōu)化等
3)InnoDB死鎖信息可以記錄到 error 日志,方便分析
4)MySQL5.6支持延時(shí)復(fù)制,可以讓slave跟master之間控制一個(gè)時(shí)間間隔,方便特殊情況下的數(shù)據(jù)恢復(fù)。
5)表分區(qū)功能增強(qiáng)
6)MySQL行級(jí)復(fù)制功能加強(qiáng),可以降低磁盤、內(nèi)存、網(wǎng)絡(luò)等資源開(kāi)銷(只記錄能確定行記錄的字段即可)
7)Binlog實(shí)現(xiàn) crash-safe
8)復(fù)制事件采用crc32校驗(yàn),增強(qiáng)master/slave 復(fù)制數(shù)據(jù)一致性
9)新增 log_bin_basename (以前variables里面沒(méi)有binlog位置信息,對(duì)數(shù)據(jù)庫(kù)的監(jiān)管很不方便)
總結(jié)
以上所述是小編給大家介紹的MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要區(qū)別整理,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
mysql drop database刪除數(shù)據(jù)庫(kù)命令實(shí)例講解
這篇文章主要介紹了mysql drop database刪除數(shù)據(jù)庫(kù)命令實(shí)例講解的相關(guān)資料,需要的朋友可以參考下2016-09-09
登錄mysql時(shí)出現(xiàn)的閃退問(wèn)題解決
大家在打開(kāi)MySQL時(shí),可能會(huì)遇到在登陸界面輸入密碼之后就閃退的這個(gè)問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于如何解決登錄mysql時(shí)出現(xiàn)的閃退問(wèn)題的相關(guān)資料,需要的朋友可以參考下2023-05-05
select?into?from和insert?into?select的區(qū)別舉例詳解
這篇文章主要介紹了SQL中的SELECT?INTO和INSERT?INTO?SELECT兩種語(yǔ)句的區(qū)別和用法,SELECT?INTO用于創(chuàng)建新表并復(fù)制數(shù)據(jù)到新表中,而INSERT?INTO?SELECT用于將數(shù)據(jù)從一個(gè)表插入到已存在的另一個(gè)表中,需要的朋友可以參考下2025-03-03
MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式
這篇文章主要介紹了MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
MySQL?時(shí)區(qū)與?serverTimezone詳解
存儲(chǔ)?TIMESTAMP?類型數(shù)據(jù)時(shí),MySQL 會(huì)根據(jù)當(dāng)前會(huì)話的時(shí)區(qū)將時(shí)間轉(zhuǎn)換為 UTC 時(shí)間,MySQL 實(shí)際存儲(chǔ)的是 UTC 時(shí)間,這篇文章主要介紹了MySQL?時(shí)區(qū)與?serverTimezone,需要的朋友可以參考下2024-12-12
QT連接MYSQL數(shù)據(jù)庫(kù)的詳細(xì)步驟
這篇文章主要介紹了QT連接MYSQL數(shù)據(jù)庫(kù)的詳細(xì)步驟,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-07-07

