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的参考手册

==== END ====

声明:原创,欢迎转载~! 记得点个关注我哦~!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270