MySQL 8.0新特性概览
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,1.事务性数据字典,完全脱离了MyISAM存储引擎真正将数据字典放到了InnoDB中的一些表中,从此不再需要FRM、TRG、PAR文件啦!Information Schema现在以数据字典表的一个视图
千家信息网最后更新 2025年11月08日MySQL 8.0新特性概览1.事务性数据字典,完全脱离了MyISAM存储引擎
真正将数据字典放到了InnoDB中的一些表中,从此不再需要FRM、TRG、PAR文件啦!Information Schema现在以数据字典表的一个视图出现。原则上可以完全不需要MyISAM数据表类型了,所有的系统表都可以放到InnoDB之中。
2.SQL角色
角色是一系列权限的集合。可以创建角色,给某个用户授予和去除角色。这对于权限管理很方便。
utf8mb4字符集将成为默认字符集,并支持Unicode 9
默认字符集将从 latin1 改为 utf8mb4,默认定序collation将从latin1_swedish_ci 改为 utf8mb4_800_ci_ai。
3.不可见索引
可以将一些索引设置为不可见,这样SQL优化器就不会用到它,但是它会继续在后台保持更新。当有需要时,可以随时恢复可见。
对二进制数据可以进行位操作
不仅仅可以对 BIGINT进行位操作,从8.0开始也支持对 [VAR]BINARY/[TINY|MEDIUM|LONG]BLOB进行位操作了。
4.改进了对IPv6和UUID的操作
INET6_ATON() 和 INET6_NTOA() 现在可以进行位操作了,因为INET6_ATON()现在返回的是VARBINARY(16) 数据类型(128位)。改进了UUID操作,引入了三个新的函数 UUID_TO_BIN(), BIN_TO_UUID()和 IS_UUID() 。MySQL并没有特殊的IPv6和UUID数据类型,而是以VARBINARY(16) 数据类型保存的。
5.持续性的全局变量
可以用 SET PERSIST 来设置持久性的全局变量,即便服务器重启也会保持下来。
性能数据库Performance Schema的改进
比如对性能数据库增加了100多个索引,可以检索更快。
6.重构SQL分析器
持续不断的逐步改进SQL分析器。旧的分析器由于其语法复杂性和自顶向下的分析方式从而有严重的限制,导致难以维护和扩展。
7.成本模型
InnoDB缓冲区现在可以估算主内存缓存区中的有多少表和索引,这可以让优化器选择访问方式时知道数据是否可以存储在内存中还是必须存储到磁盘上。
8.直方图Histograms
通过使用直方图,用户或DBA可以对数据分布进行统计,这可以用于查询优化以寻找优化的查询方案。
9.改进扫描性能
改进了InnoDB范围查询的性能,可提升全表查询和范围查询 5-20%的性能。
10.重构BLOB
重构BLOB加速了片段读取/更新操作,可以加速JSON数据的操作。
11.持久化自增值
InnoDB会持久化保持自增序列的最大值到redo日志中。这个改进还修复了一个非常老的199号bug。
12.临时表
取消对压缩临时表的支持,并存储临时表的元数据到内存中。
从MySQL8.0以后,我们可以发现MySQL做的越来越像Oracle了。
真正将数据字典放到了InnoDB中的一些表中,从此不再需要FRM、TRG、PAR文件啦!Information Schema现在以数据字典表的一个视图出现。原则上可以完全不需要MyISAM数据表类型了,所有的系统表都可以放到InnoDB之中。
2.SQL角色
角色是一系列权限的集合。可以创建角色,给某个用户授予和去除角色。这对于权限管理很方便。
utf8mb4字符集将成为默认字符集,并支持Unicode 9
默认字符集将从 latin1 改为 utf8mb4,默认定序collation将从latin1_swedish_ci 改为 utf8mb4_800_ci_ai。
3.不可见索引
可以将一些索引设置为不可见,这样SQL优化器就不会用到它,但是它会继续在后台保持更新。当有需要时,可以随时恢复可见。
对二进制数据可以进行位操作
不仅仅可以对 BIGINT进行位操作,从8.0开始也支持对 [VAR]BINARY/[TINY|MEDIUM|LONG]BLOB进行位操作了。
4.改进了对IPv6和UUID的操作
INET6_ATON() 和 INET6_NTOA() 现在可以进行位操作了,因为INET6_ATON()现在返回的是VARBINARY(16) 数据类型(128位)。改进了UUID操作,引入了三个新的函数 UUID_TO_BIN(), BIN_TO_UUID()和 IS_UUID() 。MySQL并没有特殊的IPv6和UUID数据类型,而是以VARBINARY(16) 数据类型保存的。
5.持续性的全局变量
可以用 SET PERSIST 来设置持久性的全局变量,即便服务器重启也会保持下来。
性能数据库Performance Schema的改进
比如对性能数据库增加了100多个索引,可以检索更快。
6.重构SQL分析器
持续不断的逐步改进SQL分析器。旧的分析器由于其语法复杂性和自顶向下的分析方式从而有严重的限制,导致难以维护和扩展。
7.成本模型
InnoDB缓冲区现在可以估算主内存缓存区中的有多少表和索引,这可以让优化器选择访问方式时知道数据是否可以存储在内存中还是必须存储到磁盘上。
8.直方图Histograms
通过使用直方图,用户或DBA可以对数据分布进行统计,这可以用于查询优化以寻找优化的查询方案。
9.改进扫描性能
改进了InnoDB范围查询的性能,可提升全表查询和范围查询 5-20%的性能。
10.重构BLOB
重构BLOB加速了片段读取/更新操作,可以加速JSON数据的操作。
11.持久化自增值
InnoDB会持久化保持自增序列的最大值到redo日志中。这个改进还修复了一个非常老的199号bug。
12.临时表
取消对压缩临时表的支持,并存储临时表的元数据到内存中。
从MySQL8.0以后,我们可以发现MySQL做的越来越像Oracle了。
数据
性能
查询
类型
索引
角色
分析
存储
内存
分析器
字典
字符
字符集
支持
重构
全局
变量
数据库
方式
权限
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
云南省个体工商户怎么连接服务器
辽宁电子软件开发互惠互利
嵌入式软件开发包含哪些
云服务器删除对方电话
网络安全保障工作的意义
美国众议院通过的网络安全法案
服务器数据库华为有吗
有线电视网络连接不上公司服务器
东莞市格子网络技术有限
携手共建网络安全心得体会
ibm服务器管理员密码
enum类型怎么存入数据库
网络安全教育讲师
木星服务器
软件开发中qa是做什么的
服务器 ios gzip
征兵网显示服务器错误是什么意思
松江区服务器设备回收厂家
维普数据库检查字段
u盘网络安全图片
战地1找不到服务器了
日志记录在数据库
虚拟主机和云服务器的价格对比
南通车载网络技术口碑推荐
数据库的附加
河南电商软件开发平台
dnf助手怎么提交数据库
嘉定租房网络安全
java往数据库插入大量数据
服务器dns通用