MySQL5.7.X用的好好的,为什么要用MySQL8.0
MySQL8.0.x新特性篇
一、MySQL文档存储(MySQL Document Store)
1、NoSQL + SQL = MySQL
MySQL文档存储为用户提供了开发传统SQL关系应用程序和NoSQL无架构文档数据库应用程序的最大灵活性。这消除了对单独的NoSQL文档数据库的需要。开发人员可以在同一个数据库和同一个应用程序中混合和匹配关系数据和JSON文档。例如,可以在同一个应用程序中查询这两个数据模型,结果可以是表格,表格式的数据模型或JSON格式。
2、高度可靠,完全一致
MySQL文档存储为无模式JSON文档提供多文档事务支持和完全ACID合规性。使用InnoDB作为文档存储后面的存储引擎,您可以获得与关系数据相同的数据保证和性能优势。这可确保用户获得完整数据一致性的数
据可靠性。这也使MySQL文档存储易于管理。
3、高可用性
MySQL Document Store利用MySQL Group Replication和InnoDB Cluster的所有优势来扩展应用程序并实现高可用性。文档在高可用性组的所有成员之间复制,并且事务在主服务器之间同步提交。如果一个主人失败,任何主人都可以接管另一个主人,没有停工时间。
4、在线热备份
就像文档存储利用Group Replication和InnoDB Cluster一样,它也可以与MySQL Enterprise Backup透明地协同工作。用户可以执行文档的完整,增量和部分备份。所有文档数据都与备份完成时的时间点保持一致。用户还可以灵活地执行时间点恢复,以使用MySQL binlog恢复到特定事务。
5、安全
默认情况下,MySQL和文档存储是安全的。此外,MySQL企业版的所有高级安全功能(如透明数据加密(TDE),审计,高级身份验证和防火墙)都有助于最大限度地提高安全性。
6、报告和分析
MySQL文档存储为您提供了执行CRUD操作的简便性以及从JSON文档中提取数据的SQL的强大功能。SQL的强大功能以及所有流行的报告和分析工具都可用。
7、使用方便
MySQL文档存储提供了多种语言支持的简单易用,流畅的CRUD API,以便组织可以使用他们选择的语言开发基于文档的应用程序。
8、结构
MySQL Document Store架构包含以下组件:
本机JSON文档存储 - MySQL提供本机JSON数据类型,可以高效地存储在二进制文件中,并能够创建可以编制索引的虚拟列。JSON文档会自动验证。
X插件 - X插件使MySQL能够使用X协议,并使用连接器和命令行管理程序充当服务器的客户端。
X协议 - X协议是一种基于Protobuf库的新客户端协议,适用于CRUD和SQL操作。
X DevAPI - X DevAPI是一个新的,现代的异步开发人员API,用于在X协议之上进行CRUD和SQL操作。它将集合作为新的Schema对象引入。文档存储在集合中,并具有专用的CRUD操作集。
MySQL Shell - MySQL Shell是一个支持MySQL服务器开发和管理的交互式Javascript,Python或SQL接口。您可以使用MySQL Shell执行数据查询和更新以及各种管理操作。
MySQL连接器 - 以下MySQL连接器支持X协议,使您能够以所选语言使用X DevAPI。
MySQL Connector / Node.js
MySQL Connector / PHP
MySQL Connector / Python
MySQL Connector / J.
MySQL Connector / NET
MySQL Connector / C ++
二、交易数据字典(Transactional Data Dictionary)
1、数据字典模式将字典数据存储在transactional(InnoDB)表中。数据字典表mysql与非数据字典系统表一起位于数据库中。
2、数据字典表在InnoDB名为的单个表空间中创建,该 表空间 mysql.ibd驻留在MySQL数据目录中。该mysql.ibd表空间文件必须位于MySQL数据目录和它的名字不能被修改或由其他表空间使用。
3、字典数据受同一提交,回滚和崩溃恢复功能的保护,这些功能可保护存储在InnoDB表中的用户数据。
三、SQL角色(SQL Roles)
MySQL角色是一组命名的特权。与用户帐户一样,角色可以拥有授予和撤消的权限。可以为用户帐户授予角色,该角色向帐户授予与每个角色关联的权限。这样可以为帐户分配权限集,并为授予个人权限提供了一种方便的替代方法,既可以概念化所需的权限分配,也可以实现它们。
1、创建角色:
CREATE ROLE 'app_developer', 'app_read', 'app_write';
2、给角色分配权限
授权所有权限给app_developer分组
GRANT ALL ON app_db.* TO 'app_developer';
仅授予‘查’权限给app_read分组
GRANT SELECT ON app_db.* TO 'app_read';
仅授予‘插入’、‘更新’、‘删除’权限经app_write分组
GRANT INSERT, UPDATE, DELETE ON app_db.* TO 'app_write';
3、创建四个用户,分别是一个开发人员帐户,两个只读访问权限的用户帐户,以及一个读/写访问权限的用户帐户
CREATE USER 'dev1'@'localhost' IDENTIFIED BY 'dev1pass';
CREATE USER 'read_user1'@'localhost' IDENTIFIED BY 'read_user1pass';
CREATE USER 'read_user2'@'localhost' IDENTIFIED BY 'read_user2pass';
CREATE USER 'rw_user1'@'localhost' IDENTIFIED BY 'rw_user1pass';
4、为3中创建的用户帐户分配所需的权限
GRANT 'app_developer' TO 'dev1'@'localhost';
GRANT 'app_read' TO 'read_user1'@'localhost', 'read_user2'@'localhost';
GRANT 'app_read', 'app_write' TO 'rw_user1'@'localhost';
5、撤消角色或修改角色权限
正如角色可以授予帐户一样,可以从帐户中撤消它们
REVOKE role FROM user;
修改授予角色的权限
REVOKE INSERT, UPDATE, DELETE ON app_db.* FROM 'app_write';
6、删除角色
DROP ROLE 'app_read', 'app_write';
四、默认为utf8mb4(Default to utf8mb4)
该utfmb4字符集有以下特点:
支持BMP和补充字符。
每个多字节字符最多需要四个字节。
utf8mb4与utf8mb3字符集形成对比 ,后者仅支持BMP字符,每个字符最多使用三个字节:
对于BMP字符,utf8mb4并 utf8mb3具有相同的存储特性:相同的代码值,相同的编码,相同的长度。
对于补充字符,utf8mb4 需要四个字节来存储它,而 utf8mb3根本不能存储字符。将utf8mb3列转换为时 utf8mb4,无需担心转换补充字符,因为没有。
utf8mb4是一个超集 utf8mb3,因此对于诸如以下串联的操作,结果具有字符集 utf8mb4和整理 utf8mb4_col:
五、公用表表达式(Common Table Expressions)---WITH语法
公用表表达式(CTE)是一个命名的临时结果集,它存在于单个语句的范围内,并且可以在该语句中稍后引用,可能多次
1、语法表达式
<pre class="brush:java;toolbar:false" style="padding: 0px; margin: 0px; color: rgb(51, 51, 51); font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-style: initial; text-decoration-color: initial; font-size: 1.2rem; background-color: rgb(149, 179, 215);">
WITH
cte1 AS (SELECT a, b FROM table1),
cte2 AS (SELECT c, d FROM table2)
SELECT b, d
FROM cte1 JOIN cte2 WHERE cte1.a = cte2.c;</pre>
2、递归公用表达式
<pre class="brush:java;toolbar:false" style="padding: 0px; margin: 0px; color: rgb(51, 51, 51); font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-style: initial; text-decoration-color: initial; font-size: 1.2rem; background-color: rgb(149, 179, 215);">
WITH RECURSIVE cte (n) AS(
SELECT 1
UNION ALL
SELECT n + 1 FROM cte WHERE n < 5
)SELECT * FROM cte;</pre>
执行上面语句:生成此结果,包含简单线性序列的单个列:
六、窗口功能(Window Functions)
查询中的每一行,使用与该行相关的行执行计算。
1、查询针对 val列中的CUME_DIST()值集显示每行的 值,以及类似PERCENT_RANK()函数返回的百分比等级值 。作为参考,查询还使用ROW_NUMBER()以下方式显示行号
2、查询演示 FIRST_VALUE(), LAST_VALUE()以及两个实例NTH_VALUE()
image七、其它
1、自增变量持久化
对AUTO_INCREMENT值进行持久化,MySQL重启后,该值将不会改变
2、加强DDL原子性
DDL操作的原子性,要么全部成功,要么全部回滚。
3、参数修改持久化
在线修改全局参数并持久化,通过加上PERSIST关键字,可以将修改的参数持久化到新的配置文件(mysqld-auto.cnf)中,重启MySQL时,可以从该配置文件获取到最新的配置参数。
4、group by 不再隐式排序
对于group by 字段不再隐式排序,如需要排序,必须显式加上order by。
5、允许跳过锁等待
select ... for update,select ... for share(8.0新增语法) 添加 NOWAIT、SKIP LOCKED语法,跳过锁等待,或者跳过锁定。
6、undo空间自动回收
新增了一个资源组功能,用于调控线程优先级以及绑定CPU核。
八、附加MySQL8.0的参考手册