原文地址:http://lefred.be/content/top-10-mysql-8-0-features-for-dbas-ops/ 臨時表的改進 MySQL 5.7中,所有內部臨時表都是在名為“ibtmp1”的惟一共用表空間中創建的。此外,臨時表的元數據也將存儲在記憶體中(不再存儲在.frm文 ...
原文地址:http://lefred.be/content/top-10-mysql-8-0-features-for-dbas-ops/
臨時表的改進
譯者添加截圖 在MySQL 8.0中,內部臨時表預設使用memory存儲引擎(由優化器在JOIN,UNION,…期間創建的表)的引擎,這個新引擎為VARCHAR和VARBINARY列提供了更高效的存儲(記憶體容量最大分配模式)。
譯者添加截圖以及備註:
更加詳細的臨時表相關知識參考:https://www.cnblogs.com/coderyuhui/p/10773143.html MySQL 5.7中只有ibtmp文件,臨時表的數據和undo都在該類文件中,臨時表的session斷開後其空間不會自動回收。 臨時表數據文件
SHOW VARIABLES LIKE '%innodb_temp_tablespaces_dir%';也即#innodb_tmp
臨時表undo文件
SHOW VARIABLES LIKE '%innodb_temp_data_file_path%';也即ibtmp1
session斷開後,其存放數據的臨時表數據文件空間會被自動回收。
全局變數持久化 藉助MySQL 8.0,可以設置變數並可以永久性保留。我寫了一篇專門的博客文章,您可以查看更多信息。將此語法與新的RESTART命令結合使用,可以非常輕鬆地從其shell配置MySQL。這是一個雲友好功能
不再有MyISAM系統表 有了新的本地數據字典,我們將不再需要MyISAM系統表!這些表和數據字典表現在在數據目錄中的一個名為mysql.idb的InnoDB表空間文件中創建。 這意味著,如果您不顯式使用MyISAM表(如果您關心數據,則完全不建議這樣做),則可以擁有一個沒有任何MyISAM表的MySQL實例。
大事務的UNDO表空間收縮 在MySQL 5.7中,我們已經添加了截斷撤消空間的可能性(innodb_undo_log_truncate,預設情況下禁用)。 在MySQL8中,我們更改了undo磁碟格式以支持每個undo表空間大量回滾段。同樣,預設情況下,現在在兩個單獨的undo表空間中創建了回滾段,而不是在InnoDB系統表空間中創建了(最小為2,並且可以動態設置)。 innodb_undo_tablespaces變數已經被棄用,因為我們將提供SQL命令,為DBA提供與UNDO表空間進行交互的真實介面。預設情況下,現在也啟用了undo表空間的自動截斷功能。
UTF8字元集的性能 預設字元集已從latin1更改為utf8mb4,因為UTF8在特定查詢上的速度現在快得多,快了1800% ! 現在Emojis字元無處不在,MySQL支持他們沒有問題!
Query Cache的移除 在性能審計期間,我一直建議的第一件事是禁用查詢緩存,因為它不是按設計進行伸縮的。MySQL Query Cache產生的問題比解決的問題還多,我們決定在MySQL 8.0中刪除它,因為沒有人應該使用它。 如果您的工作負載需要查詢緩存,那麼您應該查看一下proxysql作為查詢緩存的情況。
原子DDL 使用新的數據字典,MySQL 8.0現在支持原子數據定義語句(原子ddl)。 這意味著,當執行DDL時,數據字典更新、存儲引擎操作和二進位日誌中的寫操作被合併到一個原子事務中,該事務要麼完全執行,要麼完全不執行。 這提供了更好的可靠性,未完成的ddl不會留下任何不完整的數據。
更快、更完整的Performance Schema(直方圖、索引、…)和Information Schema 對Performance Schema進行了許多改進,例如偽索引或直方圖。 藉助偽索引,諸如SELECT * FROM sys.session之類的查詢速度提高了30倍。現在,儘可能避免進行表掃描,索引的使用大大縮短了執行時間。 除此之外,Performance Schema還提供語句延遲的直方圖。優化器還可以從這些新的直方圖中受益。 Performance Schema還通過使用數據字典得到了改進。無需更多.frm文件即可瞭解表的定義。而且這允許擴展到超過1,000,000個表!
ROLES(角色) MySQL 8.0中已經添加了SQL角色。角色是一個命名的特權集合。 與用戶帳戶一樣,角色可以擁有授予和撤消的特權。角色可以是預設的,也可以是會話的。也可以將角色設置為強制的。
如果表空間被加密,那麼redo log和undo log將被加密 在MySQL 5.7中,可以為存儲在每個表的文件中的表加密一個InnoDB表空間。 在MySQL 8.0中,我們通過為UNDO和REDO日誌添加加密來完成這個功能。另外,改進的列表並沒有在這裡結束。還有許多其他不錯的功能。我想下麵列出一些其他重要的(即使他們都是重要的當然)
- 自增id列的持久化,persistent auto increment
- Innodb自我優化,InnoDB self tuning
- Json欄位類型性能提升,JSON performance
- 不可見索引,Invisible Indexes
- 新的備份鎖,new lock for backup
- 資源組,Resource Groups
- binlog中的額外元數據,additional metadata into binary logs
- 社區版的OpenSSL支持,OpenSSL for Community Edition too
!!更新!! 隨著我們不斷改進MySQL 8.0的發行版,還有另一個原因需要升級到MySQL 8.0,這可能是必須處理大型表時最需要的功能之一。 開發人員將不再害怕在其架構中添加列,並且DBA / 運維將不會害怕運行它們,或者將不需要使用第三方工具來執行此(過去)複雜的任務:即時添加列!
InnoDB即時添加列 藉助新的數據字典,現在可以執行元數據更改並直接在表的末尾添加新列,而無需重建它!這是每次開發人員想要向表中添加列時,alter語句都阻塞所有session的終結者。 而這僅僅是即時ddl之旅的開始。