农村四月闲人少,勤学苦攻把名扬。这篇文章主要讲述「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!相关的知识,希望能为你提供帮助。
前提背景
- 访问地址:MySQL官网
- 下载地址:MySQL下载
MySQL8的特性介绍
- SQL窗口函数,公用表表达式,NOWAIT和SKIP LOCKED,降序索引,分组,正则表达式,字符集,成本模型和直方图。
- JSON扩展语法,新功能,改进排序和部分更新。使用JSON表函数,您可以使用JSON数据的SQL机制。
- GIS地理支持。空间参考系统(SRS),以及SRS感知空间数据类型,空间索引和空间功能。
- 可靠性 DDL语句已变得原子性和崩溃安全,元数据存储在单个事务数据字典中。由InnoDB提供支持!
- 可观察性性能架构,信息架构,配置变量和错误记录的显着增强。
- 可管理性远程管理,撤消表空间管理和新的即时DDL。
- 安全 OpenSSL改进,新的默认身份验证,SQL角色,分解超级特权,密码强度等等。
- 性能 InnoDB在读/写工作负载,IO绑定工作负载和高争用“热点”工作负载方面明显更好。
- 增加了资源组功能,通过将用户线程映射到CPU,为用户提供一个选项,以针对特定硬件上的特定工作负载进行优化
- 性能:MySQL8.0的速度要比MySQL5.7 快 2 倍。MySQL 8.0 在以下方面带来了更好的性能:读/写工作负载、IO 密集型工作负载、以及高竞争(" hot spot" 热点竞争问题)工作负载。
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H4354634-0.jpg)
文章图片
- NoSQL:MySQL从5.7版本开始提供 NoSQL 存储功能,目前在8.0版本中这部分功能也得到了更大的改进。该项功能消除了对独立的 NoSQL 文档数据库的需求,而 MySQL 文档存储也为 schema-less 模式的 JSON 文档提供了多文档事务支持和完整的ACID合规性。
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H435NT-1.jpg)
文章图片
- 窗口函数(Window Functions):从 MySQL 8.0 开始,新增了一个叫窗口函数的概念,它可以用来实现若干新的查询方式。窗口函数与 SUM()、COUNT() 这种集合函数类似,但它不会将多行查询结果合并为一行,而是将结果放回多行当中。即窗口函数不需要 GROUP BY。
- 窗口函数
- MySQL 8.0提供了SQL窗口功能。与分组集合函数类似,窗口函数对一组行进行一些计算,例如COUNT或SUM。但是,如果分组聚合将这组行集合到一行中,则窗口函数将为结果集中的每一行执行聚合。
- 窗口化的聚合函数:COUNT,SUM,AVG,MIN,MAX,BIT_OR,BIT_AND,BIT_XOR,STDDEV_POP(及其同义词STD,STDDEV),STDDEV_SAMP,VAR_POP(及其同义词VARIANCE)和VAR_SAMP。
- 专门的窗口函数是:RANK,DENSE_RANK,PERCENT_RANK,CUME_DIST,NTILE,ROW_NUMBER,FIRST_VALUE,LAST_VALUE,NTH_VALUE,LEAD和LAG
- 窗口函数
- 隐藏索引:在 MySQL 8.0 中,索引可以被“隐藏”和“显示”。当对索引进行隐藏时,它不会被查询优化器所使用。我们可以使用这个特性用于性能调试,例如我们先隐藏一个索引,然后观察其对数据库的影响。如果数据库性能有所下降,说明这个索引是有用的,然后将其“恢复显示”即可;如果数据库性能看不出变化,说明这个索引是多余的,可以考虑删掉。
- 降序索引:MySQL 8.0 为索引提供按降序方式进行排序的支持,在这种索引中的值也会按降序的方式进行排序。
- 公用表表达式(Common Table Expressions CTE):在复杂的查询中使用嵌入式表时,使用 CTE 使得查询语句更清晰。
- MySQL 8.0提供[递归]公用表表达式(CTE)。非递归CTE可以解释为“改进的派生表”,因为它允许派生表被多次引用。递归CTE是一组迭代构建的行:从最初的一组行开始,一个进程派生新的行,然后将这些新的行重新输入到进程中,产生更多的行,等等,直到该过程不再生成行。
- UTF-8 编码:从 MySQL 8 开始,使用 utf8mb4 作为 MySQL 的默认字符集。
- JSON:MySQL 8 大幅改进了对 JSON 的支持,添加了基于路径查询参数从 JSON 字段中抽取数据的 JSON_EXTRACT() 函数,以及用于将数据分别组合到 JSON 数组和对象中的 JSON_ARRAYAGG() 和 JSON_OBJECTAGG() 聚合函数。
- 可靠性:InnoDB 现在支持表 DDL 的原子性,也就是 InnoDB 表上的 DDL 也可以实现事务完整性,要么失败回滚,要么成功提交,不至于出现 DDL 时部分成功的问题,此外还支持 crash-safe 特性,元数据存储在单个事务数据字典中。
- 高可用性(High Availability):InnoDB 集群为您的数据库提供集成的原生 HA 解决方案。
- 安全性:对 OpenSSL 的改进、新的默认身份验证、SQL 角色、密码强度、授权。
- 进入官网后,点击"
Dowload"
,然后页面往下拉
文章图片
- 接下来看到的页面是这样的,红色框框的链接就是mysql社区版,是免费的mysql版本,然后我们点击这个框框的链接:
文章图片
- 接下来跳转到这个页面,在这里,我们只要下载社区版的Server就可以了:
文章图片
- 下载免安装版(windows以外的其他系统除外)
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H4356062-5.jpg)
文章图片
- 至此,安装包就下载好了!
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H4352632-6.jpg)
文章图片
MySQL解压和配置环境变量
- 找一个文件夹放入解压后的mysql,不建议放c盘,200M左右的sql解压后大约接近1G
- 把MySQL解压后的bin文件地址加入环境变量的path,方便终端寻找MySQL命令行。
# 这些是基本配置信息
[client]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[mysqld]
# 设置3336端口
port = 3336
# 设置mysql的安装目录
basedir=D:\\developer\\installed\\mysql8\\mysql-8.0.12-winx64
# 设置 mysql数据库的数据的存放目录
datadir=D:\\developer\\installed\\mysql8\\mysql-8.0.12-winx64\\data
# 允许最大连接数
max_connections=20
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 允许连接失败的次数。
max_connect_errors=10
# 服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
# 使用“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
#设置时区为东八区,此项设置后,在连接MySQL的时候可以不用每次都手动设置时区
default-time-zone = \'+8:00\'
- mysql给出的初始密码太复杂了,一般我们需要改为一个简单的密码方便之后登陆,在MySQL8.0.4以前,执行:SET PASSWORD=PASSWORD(’[修改的密码]’),即可更改密码,但MySQL8.0.4开始,这样默认是不行的。因为之前,MySQL的密码认证插件是“mysql_native_password”,而现在使用的是“caching_sha2_password”。
- 因为当前有很多数据库工具和链接包都不支持“caching_sha2_password”,为了方便,暂时需要改回“mysql_native_password”认证插件。
- mysql会在和bin同级目录下产生data文件,即root的数据库,并产生如下红框中的随机密码(如果没有密码,可以使用mysql -uroot -p直接登陆),对应账号为root。在没有更改密码前,需要记住这个密码,后续登录需要用到。
文章图片
- 还在bin 目录下执行命令
mysqld --install [服务名]
- 在mysql的bin目录下面执行: mysqld --install
- 报错信息如下:Install/Remove of the Service Denied
- 解决办法:打开cmd.exe程序的时候选择“用管理员身份打开”。
- 报错信息如下:Install/Remove of the Service Denied
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H4351491-8.jpg)
文章图片
启动MySQL服务输入:
net start [服务名]
【「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!】
![「推荐收藏!」MySQL技术之旅该换换你的数据库版本了,让我们一同迎接8.0的到来哦!](http://img.readke.com/220527/1H43540B-9.jpg)
文章图片
登录MySQL服务
- 登录指定端口3336
输入ALTER USER "root"@"localhost" IDENTIFIED BY "新密码";
卸载MySQL服务 停止服务卸载服务参考资料
- https://www.cnblogs.com/2020javamianshibaodian/p/12933674.html
- https://www.jianshu.com/p/647a596cb251
- https://www.jb51.net/article/218165.htm
- https://blog.csdn.net/qq_32448349/article/details/81701355
推荐阅读
- 8个Date命令使用示例
- Linux中rsync备份数据使用实例
- netty系列之:使用netty搭建websocket客户端
- 用Python绘制移动均线含源代码
- kubeadm初始化kubernetes报错以及解决
- t-io网络编程基础知识介绍
- 2021.7 货拉拉虾皮有赞。。。高级前端岗面试整理
- 鸿蒙应用开发(如何与组件库(Glide)衔接())
- Interrupted Exception异常可能没你想的那么简单!