首页 > 数据库 >MySQL 8.0.0 开发里程碑版本(DMR)发布!

MySQL 8.0.0 开发里程碑版本(DMR)发布!

时间:2023-03-24 23:58:59浏览次数:60  
标签:8.0 UUID 可以 DMR InnoDB 版本 MySQL

MySQL 为何从 5.x 一下跳跃到了 8.0。事实上,MySQL 5.x 系列已经延续了很多年,从被 Oracle 收购之前就是 5.1,而收购之后一直维持在 5.x,比如 5.5,5.6,5.7 等等。

MySQL 开发团队于 12 日宣布 MySQL 8.0.0 开发里程碑版本(DMR)发布!

可能有人会惊奇 MySQL 为何从 5.x 一下跳跃到了 8.0。事实上,MySQL 5.x 系列已经延续了很多年,从被 Oracle 收购之前就是 5.1,而收购之后一直维持在 5.x,比如 5.5,5.6,5.7 等等。其实,如果按照原本的发布节奏,可以把 5.6.x 当成 6.x,5.7.x 当成 7.x。所以,只是换了版本命名方式而已。

不过这次发布的 MySQL 8.0.0 开发版本还是有不少亮点的。

MySQL 8.0.0 亮点

事务性数据字典,完全脱离了 MyISAM 存储引擎

真正将数据字典放到了 InnoDB 中的一些表中,从此不再需要 FRM、TRG、PAR 文件啦!Information Schema 现在以数据字典表的一个视图出现。原则上可以完全不需要 MyISAM 数据表类型了,所有的系统表都可以放到 InnoDB 之中。

SQL 角色

角色是一系列权限的集合。可以创建角色,给某个用户授予和去除角色。这对于权限管理很方便。

utf8mb4 字符集将成为默认字符集,并支持 Unicode 9

默认字符集将从latin1改为utf8mb4,默认定序(collation)将从latin1_swedish_ci 改为utf8mb4_800_ci_ai。

不可见索引

可以将一些索引设置为不可见,这样 SQL 优化器就不会用到它,但是它会继续在后台保持更新。当有需要时,可以随时恢复可见。

对二进制数据可以进行位操作

不仅仅可以对BIGINT进行位操作,从 8.0 开始也支持对[VAR]BINARY/[TINY|MEDIUM|LONG]BLOB进行位操作了。

改进了对 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)数据类型保存的。

持续性的全局变量

可以用SET PERSIST来设置持久性的全局变量,即便服务器重启也会保持下来。

性能数据库(Performance Schema)的改进

比如对性能数据库增加了 100 多个索引,可以检索更快。

重构 SQL 分析器

持续不断的逐步改进 SQL 分析器。旧的分析器由于其语法复杂性和自顶向下的分析方式从而有严重的限制,导致难以维护和扩展。

成本模型

InnoDB 缓冲区现在可以估算主内存缓存区中的有多少表和索引,这可以让优化器选择访问方式时知道数据是否可以存储在内存中还是必须存储到磁盘上。

直方图(Histograms)

通过使用直方图,用户或 DBA 可以对数据分布进行统计,这可以用于查询优化以寻找优化的查询方案。

改进扫描性能

改进了 InnoDB 范围查询的性能,可提升全表查询和范围查询 5-20% 的性能。

重构 BLOB

重构 BLOB 加速了片段读取/更新操作,可以加速 JSON 数据的操作。

持久化自增值

InnoDB 会持久化保持自增序列的最大值到 redo 日志中。这个改进还修复了一个非常老的 199 号 bug。

临时表

取消对压缩临时表的支持,并存储临时表的元数据到内存中。

目前 8.0.0 还是开发版本,如果你希望体验和测试最新特性,可以下载各个平台的安装包。不过,MySQL 软件包是越来越大了,Linux 平台上的二进制打包后就将近有 1 GB。如果在产品环境中使用,在 8.0 没有进入稳定版本之前,请继续使用 5.7 系列,当前最新的版本是 5.7.15 GA 版本——这只有 600 M 多。

最新的源代码放在GitHub上,感兴趣的朋友可以去看看,其中有不少是中国人的贡献。

标签:8.0,UUID,可以,DMR,InnoDB,版本,MySQL
From: https://www.cnblogs.com/cainiaoyige1/p/17253727.html

相关文章

  • P1 命令行连接到MySql
    使用命令行窗口连接MySQL数据库mysql-h主机名-P端口-u用户名-p密码注意:(1)“-p密码”之间不要有空格(2)-p后面如果没有写密码,回车会要求输入密码(3)如果......
  • MySQL MVCC
    目录前言共享锁和排它锁什么是当前读和快照读?当前读快照读MVCCReadView流程RR、RC生成ReadView的时机总结前言MVCC,全称Multi-VersionConcurrencyControl,即多版本并......
  • MySQL主从复制
    原理   主从复制相关线程主节点:dumpThread:为每个Slave的I/OThread启动一个dump线程,用于向其发送binarylogevents从节点:I/OThread:向Master请求二进制日......
  • MySQL数据库备份与恢复
    一,备份,恢复为什么要备份灾难恢复:硬件故障、软件故障、自然灾害、黑客攻击、误操作测试等数据丢失场景参考链接:https://www.toutiao.com/a6939518201961251359/ ......
  • mysql如何优雅删除大表? 看这篇就够了
    MySQL大表删除有次线上用droptablexxx删除200G的大表,导致MySQL连接数暴涨,业务出现大量5XX,“喜提”一个事故报告。看来还是忽略了一行命令背后产生的“蝴蝶效应”,现在让......
  • 力扣570(MySQL)-至少有5名直接下属的经理(简单)
    题目:Employee表包含所有员工和他们的经理。每个员工都有一个Id,并且还有一列是经理的Id。 给定Employee表,请编写一个SQL查询来查找至少有5名直接下属的经理。对于......
  • Winform/Csharp中连接Mysql并执行指定sql,查询结果通过反射映射为对象的List
    场景Winform中连接Mysql8并查询表中数据进行显示:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/120395988在上面连接Mysql的基础上,如果需要连接Mysql并执......
  • mysql 订单产品表,一个订单对应多个产品,查询只包含产品A001,A002,A003的订单
    假设订单产品表的表名为order_product,包含字段如下:order_id:订单IDproduct_id:产品ID下面是查询只包含产品A001,A002,A003的订单的SQL语句:SELECTorder_idFROMorder......
  • 在docker上安装MySQL和Redis
    1.通过docker命令下载mysql5.7镜像mysql5.7前期准备2.通过docker命令下载mysql8.0镜像mysql8.0前期准备3.通过docker命令下载redis镜像redis前期准备本文永......
  • MYSQL注入流程
    一、判断注入点(与数据库有交互的地方)浏览网站各个地方-->查找有可控参数的地方(特别注意url)并观察网站页面变化情况  根据参数传输方式传输的不同,可以把SQL注入分为GE......