Bootstrap

🐬【MySQL技术专题】该换换你的数据库版本了,让我们一同迎接8.0的到来哦!(初探篇)

前提背景

MySQL关是一种关系数据库管理系统,所使用的 SQL 语言是用于访问数据库的最常用的标准化语言,其特点为体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,在 Web应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。本文主要讲述压缩版,因为安装不太方便,但是功能效果都是一样的!

  • 访问地址:

  • 下载地址:

MySQL8的介绍说明

MySQL 8.0是全球最受欢迎的开源数据库的一个非常令人兴奋的新版本,全面改进。一些关键的增强包括:

MySQL8的特性介绍

  • SQL窗口函数,公用表表达式,NOWAIT和SKIP LOCKED,降序索引,分组,正则表达式,字符集,成本模型和直方图。

  • JSON扩展语法,新功能,改进排序和部分更新。使用JSON表函数,您可以使用JSON数据的SQL机制。

  • GIS地理支持。空间参考系统(SRS),以及SRS感知空间数据类型,空间索引和空间功能。

  • 可靠性 DDL语句已变得原子性和崩溃安全,元数据存储在单个事务数据字典中。由InnoDB提供支持!

  • 可观察性性能架构,信息架构,配置变量和错误记录的显着增强。

  • 可管理性远程管理,撤消表空间管理和新的即时DDL。

  • 安全 OpenSSL改进,新的默认身份验证,SQL角色,分解超级特权,密码强度等等。

  • 性能 InnoDB在读/写工作负载,IO绑定工作负载和高争用“热点”工作负载方面明显更好。

  • 增加了资源组功能,通过将用户线程映射到CPU,为用户提供一个选项,以针对特定硬件上的特定工作负载进行优化

开发者需要了解的特性!

MySQL开发人员需要新功能,而MySQL 8.0在诸如SQL,JSON,正则表达式和GIS等领域提供了许多新的和更多需求的功能。开发人员也希望能够存储Emojis,因此UTF8MB4现在是8.0中的默认字符集。最后,数据类型得到了改进,在BINARY数据类型上进行了按位操作,并且改进了IPv6和UUID功能。

下面简要介绍 MySQL 8 中值得关注的新特性和改进。

对窗口函数(又名分析函数)的支持是一种频繁的用户请求

MySQL8的安装介绍

  • 进入官网后,点击"Dowload",然后页面往下拉

  • 接下来看到的页面是这样的,红色框框的链接就是mysql社区版,是免费的mysql版本,然后我们点击这个框框的链接:

  • 接下来跳转到这个页面,在这里,我们只要下载社区版的Server就可以了:

  • 下载免安装版(windows以外的其他系统除外)

  • 至此,安装包就下载好了!

注意,安装的目录应当放在指定位置,其次,绝对路径中避免出现中文,推荐首选英文为命名条件!

MySQL解压和配置环境变量

MySQL 创建配置

下载完后,建议解压到一个没有中文的路径,在解压目录创建my.ini配置文件(如果没有就自己手动建立一个即可)

添加相关基本配置
# 这些是基本配置信息
[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服务

采用cmd进入解压后的bin目录,输入mysqld --initialize --console

  • mysql会在和bin同级目录下产生data文件,即root的数据库,并产生如下红框中的随机密码(如果没有密码,可以使用mysql -uroot -p直接登陆),对应账号为root。在没有更改密码前,需要记住这个密码,后续登录需要用到。

安装MySQL服务
  • 还在bin 目录下执行命令

mysqld --install [服务名]

后面的服务名可以不写,默认的名字为 mysql。当然,如果电脑上需要安装多个MySQL服务,就可以用不同的名字区分了,比如 liboMySQL

  • 在mysql的bin目录下面执行: mysqld --install

  • 报错信息如下:Install/Remove of the Service Denied

  • 解决办法:打开cmd.exe程序的时候选择“用管理员身份打开”。

出现上述信息则标识成功安装

启动MySQL服务

输入:

登录MySQL服务
  • 登录指定端口3336

命令如下,这时候会提示输入密码,使用上面安装时给的随机密码,填入即可登录成功,进入MySQL命令模式。

mysql -u root -p 3336
修改密码

刚才生成的是临时密码,得改。

输入ALTER USER "root"@"localhost" IDENTIFIED BY "新密码";

卸载MySQL服务

停止服务

net stop libomysql(服务名)

卸载服务

mysqld --remove libomysql(服务名)

参考资料

  • 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