为什么要升级到mysql8

转自: https://www.jianshu.com/p/7259a2f0e95a

侵删

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

 

 

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

### MySQL 8 升级MySQL 9 的方法和注意事项 目前,MySQL官方尚未正式发布MySQL 9版本[^3]。根据MySQL的开发路线图和社区动态,MySQL 9可能是未来的一个主要版本,但具体的时间表和功能特性尚未明确。然而,可以基于当前已知的升级原则和最佳实践,推测从MySQL 8升级到更高版本(如MySQL 9)时可能涉及的步骤和注意事项。 以下是可能的升级步骤和兼容性问题分析: #### 1. **备份数据** 在任何数据库升级之前,确保对现有数据进行全面备份。这可以通过以下方式实现: - 使用`mysqldump`工具导出所有数据库内容。 - 或者直接复制数据目录(确保服务器已停止运行以避免数据不一致)。 ```bash mysqldump -u root -p --all-databases > full_backup.sql ``` 此步骤对于防止数据丢失至关重要[^4]。 #### 2. **检查系统要求** 确认目标系统满足MySQL 9的最低硬件和软件要求。通常包括操作系统版本、文件系统支持以及必要的库文件。例如,某些新功能可能需要更新的操作系统或特定的编译器支持。 #### 3. **下载并安装MySQL 9** 当MySQL 9发布后,从官方站点下载对应的二进制包或源代码,并按照文档说明进行安装。如果使用的是RPM或DEB包管理器,则可以通过以下命令完成安装: ```bash sudo apt-get install mysql-server-9.0 # 或者对于基于RPM的系统 sudo yum install mysql-server-9.0 ``` #### 4. **执行升级过程** 类似于从MySQL 5.7到8.0的升级流程,在启动新的MySQL 9实例时,它会自动检测并尝试升级元数据结构。此外,还需要手动运行`mysql_upgrade`工具来确保所有系统表和用户表得到正确更新。 ```bash mysql_upgrade -u root -p ``` 注意:如果MySQL 9引入了新的认证插件或其他重大变更,则需要调整相关配置文件或SQL语句以适应这些变化[^5]。 #### 5. **处理兼容性问题** - **身份验证插件**:如同从MySQL 8迁移到更高版本时一样,可能会出现默认身份验证插件的变化。例如,`caching_sha2_password`可能被替换为更安全的新插件。此时需重新设置用户的密码策略。 ```sql ALTER USER 'user'@'host' IDENTIFIED WITH new_plugin BY 'password'; ``` - **废弃功能移除**:随着版本迭代,部分旧功能会被彻底移除。建议提前查阅MySQL 9的发行说明,了解哪些功能已被淘汰,并修改应用程序代码以规避潜在问题。 - **字符集与排序规则**:MySQL 9或许会对默认字符集或排序规则作出更改。务必验证现有数据库是否受到影响,并适时调整。 #### 6. **测试与验证** 完成上述操作后,必须全面测试升级后的环境,确保所有业务逻辑正常运作。特别关注存储过程、触发器及视图等功能组件的表现。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值