MySQL8.0.28安装教程全程参考MySQL官方文档

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL8.0.28安装教程全程参考MySQL官方文档为了MySQL8.0.28安装教程我竟然在MySQL官方文档逛了一天,至此献给想入门MySQL8.0的初学者。以目前最新版本的MySQL8.0.28为示例进行安装与初步使用的详细讲解,面向初学者的详细教程。无论是Windows还是Linux上安装,咱都会。这也许是迄今为止全网最最最详细的MySQL8.0.28的安装与使用教程。

MySQL8.0.28安装教程全程参考MySQL官方文档

网络异常,图片无法展示
|

前言

为了MySQL8.0.28安装教程我竟然在MySQL官方文档逛了一天,至此献给想入门MySQL8.0的初学者。以目前最新版本的MySQL8.0.28为示例进行安装与初步使用的详细讲解,面向初学者的详细教程。无论是Windows还是Linux上安装,咱都会。这也许是迄今为止全网最最最详细的MySQL8.0.28的安装与使用教程

温故而知新,可以为师矣。咱缺的是学习的途径吗?答案并不是,而是缺乏学习的方法。官方文档是很详细的,而且是权威的,其它的那些书籍、博文啊都是基于官方文档以及自己的使用经验总结的。写这篇文章的用意,希望大家可以总结自己的学习方法,善于利用官方文档来提升自己。

建议初学者多在命令行窗口下进行练习,熟能生巧。达到一定的熟练程度,再借助客户端工具提高我们的工作效率。最终目的是啥?活下去呗,提高捞金能力。当然开个玩笑,回到正题,接着往下看。

网络异常,图片无法展示
|

从下载到安装,再到忘记密码解决方案。一步步使用命令行窗口学会基本操作,然后使用客户端远程连接工具。最后配合时下比较火热的Java语言进行演示如何使用JDBC连接最新的MySQL8.0数据库,以及执行查询返回结果。

正文

咱也不多哔哔,直接上干货,要的就是实用性和性价比!

一、MySQL8.0.28下载

可以下载msi文件一键安装或者解压版zip文件进行命令行初始化安装。

MySQL官网下载地址

https://dev.mysql.com/downloads/mysql/

1、Windows版本下载

在Windows下可以选择下载msi文件或者解压版zip文件。一般使用,选择我使用紫色框线选中的即可。关于下面的Debug Test Suite,是带有许多的测试套件在里面,对于有测试需求的人员可以进行下载。

网络异常,图片无法展示
|

2、Linux版本下载

根据自己需要的Linux发行版版本适配的MySQL进行选择。比如,我个人选择的是自己比较熟悉的Redhat7系列进行下载。同样有bundle版本,包含了一些插件和依赖在里面,便于使用rpm包安装。安装单个的server服务,需要安装其它的依赖包比较繁琐。对于初学者,建议直接下载RPM bundle版本。我偏不,就要折腾。那也行,请接着往下看,一样提供了详细安装步骤。

网络异常,图片无法展示
|

3、注意事项

一般人可以能没仔细看,官方会提示登录,加了button按钮字体非常显眼,而下面的的我需要立即下载则字体很小。所以注意了,选择下面的No thanks,我需要立即下载。选择的是社区版本,免费提供下载。

网络异常,图片无法展示
|

二、MySQL8.0安装

初学者尝鲜,建议在Windows下安装

一般情况,默认安装一个MySQL版本服务实例。也不排除预算有限,在同台服务器上安装多个实例进行测试。默认端口3306,如果在发布(生产)环境建议修改默认端口,达到不让别人一下就猜到的目的。接下来安装测试多个MySQL服务版本共存一个操作系统下,只针对于Windows下安装多个服务(没有使用虚拟机工具,真机环境下测试)。Linux下有便捷的yum源以及apt方式安装,一键安装所需依赖,但也有比较繁琐的rpm包安装。

1、Windows下安装

配置环境变量,编辑系统环境变量,控制面板>所有控制面板项>系统>高级系统配置>系统环境变量

#变量名
MySQL_HOME
#变量值
D:\work\mysql-8.0.28-winx64\bin

网络异常,图片无法展示
|

msi文件安装就不介绍了,傻瓜式的一键安装,注意选择路径

主要介绍解压版本zip的安装与实例化

mysql-8.0.28-winx64.zip

1.1、解压上面准备的安装包mysql-8.0.28-winx64.zip

在解压后的D:\work\mysql-8.0.28-winx64目下新增my.ini文件,默认解压版是没有的。然后加入如下配置:

[client]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
# 设置3307端口,有多个服务,为了不冲突修改默认的3306端口为3307
port=3307
# 设置mysql的安装目录
basedir=D:\\work\\mysql-8.0.28-winx64
# 设置 mysql数据库存放目录
datadir=D:\\work\\mysql-8.0.28-winx64\\data
# 允许最大连接数
max_connections=20
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

1.2、实例化

以管理员身份运行CMD命令窗口,切换到mysql解压后的目录下:

-- 第一步执行d:,切换到D盘
d:
-- 第二步执行cd命令,切换到个人安装mysql的bin目录下
cd D:\work\mysql-8.0.28-winx64\

设置为空密码,去掉不必要的麻烦。

mysqld --initialize-insecure

1.3、安装服务

进入到解压后MySQL的bin目录下,执行安装服务命令:

cd D:\work\mysql-8.0.28-winx64\bin
mysqld install
mysqld install --service -mysql8

如果没有安装多个服务,使用mysqld install即可。可以不用指定服务名,默认的服务名为MySQL。

1.4、服务命令使用,需要管理员身份运行CMD命令,注意看我的路径是在bin目录下执行的

我没有配置MySQL8的系统环境变量,所以都在MySQL的bin目录中执行命令。

启动服务net start mysql

# 启动服务
net start mysql
D:\work\mysql-8.0.28-winx64\bin>net start mysql8
MySQL8 服务正在启动 .
MySQL8 服务已经启动成功。

停止服务net stop mysql

# 停止服务
net stop mysql 
D:\work\mysql-8.0.28-winx64\bin>net stop mysql8
MySQL8 服务正在停止..
MySQL8 服务已成功停止。

删除服务sc delete mysql

# 删除服务
sc delete mysql
# 或者mysqld remove删除服务,需要在mysql的bin目录下执行mysqld命令
mysqld remove mysql

1.5、注意事项

# 安装服务指定了服务名为MySQL8
计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL8
# 或者是MySQL
计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL

安装服务指定了服务名为MySQL8。在下面的多实例服务共存也提到过,需要将原始残留的注册表删掉,重启电脑,再进行安装即可。

出现了丢失MSVCR120.dll,缺少组件,安装以下组件解决

vcredist_x64.exe

vcredist_x86.exe

Download Visual C++ Redistributable Packages for Visual Studio 2013 from Official Microsoft Download Center

注意:使用了mysqld -initialize,密码是随机生成的,在mysql的错误日志中可以找到

例如我的日志(mysql的data中以.err结尾的文件)

A temporary password is generated for root@localhost: 6hk20yueza=M

修改密码的命令

ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码'

之所以在Windows下介绍的如此详细,是因为我们平时的工作环境更多的是在Windows下进行的。就算使用Linux环境一般也是使用虚拟机配合Linux发行版,再就是云服务器了。MySQL的一些命令都熟悉了,Linux下安装还能难倒你吗?直接翻一翻官方文档即可。

2、Linux下安装

建议初学者不要像我这样去安装rpm包,你可以直接下载rpm bundle,或者使用mysql官方的yum源。个人有多年Linux使用经验,以及有一定的实际工作经验;知道如何判断哪些包是必须的,以及哪些需要被替换掉。

一定要注意Linux操作系统的权限问题权限在最小范围内满足即可

2.1、准备好安装包

直接在官网下载,或者使用wget命令下载都可以,同样可以使用官网的yum源进行安装。亦或是使用apt命令获取安装。至于为什么一些Linux发行版将MySQL从默认中移除了,因为MySQL被Oracle收购后存在闭源的风险。取而代之的是她的妹妹MariaDB,这也是为什么我在安装的时候提到了MariaDB。

2.2、安装rpm包

系统会提示哪些是需要的依赖包,所以我事先准备需要的依赖包

网络异常,图片无法展示
|

[mysql@localhost ~]$ rpm -ivh mysql-community-server-8.0.28-1.el7.x86_64.rpm 
警告:mysql-community-server-8.0.28-1.el7.x86_64.rpm: 头V4 RSA/SHA256 Signature, 密钥 ID 3a79bd29: NOKEY
错误:依赖检测失败:
  mysql-community-client(x86-64) >= 8.0.11 被 mysql-community-server-8.0.28-1.el7.x86_64 需要
  mysql-community-common(x86-64) = 8.0.28-1.el7 被 mysql-community-server-8.0.28-1.el7.x86_64 需要
  mysql-community-icu-data-files = 8.0.28-1.el7 被 mysql-community-server-8.0.28-1.el7.x86_64 需要
[root@localhost mysql]# rpm -ivh mysql-community-icu-data-files-8.0.28-1.el7.x86_64.rpm 
警告:mysql-community-icu-data-files-8.0.28-1.el7.x86_64.rpm: 头V4 RSA/SHA256 Signature, 密钥 ID 3a79bd29: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:mysql-community-icu-data-files-8.################################# [100%]
[root@localhost mysql]# rpm -ivh mysql-community-common-8.0.28-1.el7.x86_64.rpm 
警告:mysql-community-common-8.0.28-1.el7.x86_64.rpm: 头V4 RSA/SHA256 Signature, 密钥 ID 3a79bd29: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:mysql-community-common-8.0.28-1.e################################# [100%]
[root@localhost mysql]# rpm -ivh mysql-community-client-8.0.28-1.el7.x86_64.rpm 
警告:mysql-community-client-8.0.28-1.el7.x86_64.rpm: 头V4 RSA/SHA256 Signature, 密钥 ID 3a79bd29: NOKEY
错误:依赖检测失败:
  mysql-community-client-plugins = 8.0.28-1.el7 被 mysql-community-client-8.0.28-1.el7.x86_64 需要
  mysql-community-libs(x86-64) >= 8.0.11 被 mysql-community-client-8.0.28-1.el7.x86_64 需要

2.2.1、安装依赖包,然后使用rpm -qa | grep mysql查询哪些被安装了。怎么传到服务器上,简单一点scp命令即可。

网络异常,图片无法展示
|

rpm -ivh mysql-community-common-8.0.28-1.el7.x86_64
rpm -ivh mysql-community-libs-8.0.28-1.el7.x86_64
rpm -ivh mysql-community-icu-data-files-8.0.28-1.el7.x86_64
rpm -ivh mysql-community-client-8.0.28-1.el7.x86_64
rpm -ivh mysql-community-client-plugins-8.0.28-1.el7.x86_64
[root@localhost mysql]# rpm -qa | grep mysql

2.2.2、Redhat7系列需要卸载原有的mariadb-libs,替换为mysql-community-libs依赖

$ yum remove mariadb-libs

2.2.3、正式安装server

$ rpm -ivh mysql-community-server-8.0.28-1.el7.x86_64.rpm

查看安装的版本Ver 8.0.28 for Linux on x86_64

[mysql@localhost ~]$ mysqladmin --version
mysqladmin  Ver 8.0.28 for Linux on x86_64 (MySQL Community Server - GPL)

2.2.4、赋予mysql安装目录所有者为mysql用户,rpm包默认安装后的路径在/var/lib/mysql。在授予mysql用户所有者和所属组权限之后,你可以使用mysql用户进行登录或者启动服务与关闭服务。

网络异常,图片无法展示
|

#添加mysql组
$ groupadd mysql
#新增mysql用户到mysql组中
$ useradd -g mysql mysql
#修改mysql用户密码
$ mysql passwd
#修改所有者
$ chown -R mysql:mysql /var/lib/mysql

tips:你也可以将mysql用户加入到/etc/sudoers配置文件中,限制mysql用户使用的权限。

2.3、初始化

设置密码为空,后续登录可修改密码

$ mysqld --initialize-insecure

2.4、启动服务与查看服务状态

网络异常,图片无法展示
|

Redhat7系列使用命令启动MySQL服务

$ systemctl start mysqld

设置开机自启

$ systemctl enable mysqld

关闭服务

$ systemctl stop mysqld

重启服务

$ systemctl restart mysqld

登录mysql

$ mysql -uroot -p

2.5、设置防火墙

加入mysql服务以及需要的端口3306

$ firewall-cmd --zone=public --add-port=3306/tcp --permanent
$ firewall-cmd --zone=public --add-service=mysql --permanent
$ firewall-cmd --reload

或者临时关闭防火墙测试

$ systemctl stop firewalld.service

2.6、测试远程登录

开启防火墙,加入了3306/tcp协议规则,加入了mysql服务规则。设置了以前旧的密码缓存验证规则 mysql_native_password,,解决caching_sha2_password验证插件无法被加载的问题。

mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'Mysql@123456'; -- 第一步创建用户
mysql> GRANT ALL ON *.* TO root@'%'; -- 第二步授权
mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Mysql@123456'; -- 第三步修改密码验证方式
mysql> flush privileges; -- 第四步刷新权限

网络异常,图片无法展示
|

3、关于忘记密码解决方案

很多小伙伴估计都遇到过设置密码后,结果忘记密码了。本文的解决方案,完全适用目前最新版本MySQL8.0.28,亲自测试验证过

参考MySQL8.0官方文档以及stackoverflow解决方法。结果兜兜转转回到了跳过登录密码权限验证,8.0版本之前的方法失效了,咱没跟上MySQL更新的步伐。

1、关闭MySQL服务:

$ systemctl stop mysqld

2、设置MySQL环境选项参数,跳过权限表验证

$ systemctl set-environment MYSQLD_OPTS="--skip-grant-tables"

或者在/etc/my.cnf文件中添加,是一样的效果。最后记得去掉跳过验证。Windows下在my.ini文件中加入skip-grant-tables。

[mysqld]
skip-grant-tables

3、使用了刚刚的设置启动mysql

$ systemctl start mysqld

4、登录到root

$ mysql -u root

5、使用命令更新root用户密码

mysql> UPDATE mysql.user SET authentication_string = PASSWORD('MyNewPassword')
 -> WHERE User = 'root' AND Host = 'localhost';
mysql> FLUSH PRIVILEGES;
mysql> quit

a、这种方式可能行不通

UPDATE user SET authentication_string = PASSWORD('123456') WHERE User = 'root' AND Host = 'localhost';

b、采取将密码先置空

update user set authentication_string = '' where user = 'root';

6、修改密码,解决方案,设置更强的密码规则即可

As mentioned my shokulei in the comments, for 5.7.6 and later, you should use 
   mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
Or you'll get a warning

MySQL8.0出现这种情况请设置更安全的密码规则比如设置密码为:Mysql@123456,即可成功。

ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'Mysql@123456';

7、关闭mysql服务

$ systemctl stop mysqld

8、重置前面设置的mysql环境变量参数

$ systemctl unset-environment MYSQLD_OPTS

9、再次启动mysql

$ systemctl start mysqld

最终成功登录到mysql

$ mysql -u root -p

三、MySQL8.0使用

主要基于Windows10进行说明的,一些命令同样适用于Linux。

1、Windows多个MySQL服务实例共存

注意修改注册表路径,解决启动MySQL服务意外停止的情况,提示1067还是1068来着。

net start mysql8
net start mysql

为了测试演示最新版本,我将服务名改成了MySQL8。

网络异常,图片无法展示
|

# 安装服务指定了服务名为MySQL8
计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL8
# 或者是MySQL
计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL

我之前安装的MariaDB10.5.6。我想继续使用MariaDB,又想体验最新版的MySQL8.0.28,选择这样处理。

网络异常,图片无法展示
|

1.1、登录并指定端口3307,默认为3306,我的MariaDB已经占用了3306端口。个人测试演示多个实例共存改了端口为3307

注意:在Windows下使用cmd命令窗口以管理员身份运行登录,没有配置环境变量也没关系,切换到MySQL安装的bin目录下执行命令。

-- 第一步执行d:,切换到D盘
d:
-- 第二步执行cd命令,切换到个人安装mysql的bin目录下
cd D:\work\mysql-8.0.28-winx64\bin
-- 执行登录命令,并指定端口
mysql -uroot -p -P 3307
-- 查询数据库版本
```sql
mysql> select version();
+-----------+
| version() |
+-----------+
| 8.0.28    |
+-----------+
1 row in set (0.00 sec)
```

网络异常,图片无法展示
|

总结一下:

  • 第一步执行d:,切换到D盘;
  • 第二步执行cd命令,切换到个人安装mysql的bin目录下;
  • 第三步执行登录命令,并指定端口登录到mysql;
  • 最后进行简单的交互,并查询数据库版本。

1.2、初步使用命令行模式进行交互

网络异常,图片无法展示
|

2、权限设置

2.1、参考官方文档

设置远程登录权限,以及密码校验规则,与安装数据库版本默认使用的默认认证插件有关

参考MySQL官方文档:https://dev.mysql.com/doc/refman/8.0/en/upgrading-from-previous-series.html#upgrade-caching-sha2-password

01、Authentication plugin 'caching_sha2_password' is not supported
02、Authentication plugin 'caching_sha2_password' cannot be loaded:
dlopen(/usr/local/mysql/lib/plugin/caching_sha2_password.so, 2):
image not found
03、Warning: mysqli_connect(): The server requested authentication
method unknown to the client [caching_sha2_password]

使用上面这种密码缓存验证算法。描述到验证插件不支持caching_sha2_password,不能被加载,服务连接请求提出警告认证方法无法识别客户端。通俗一点解释:在使用SQLyog、MySQL workbench等客户端连接时,密码验证规则是不被允许的。需要更换验证方式,或者其它方式解决验证。下面将会给出解决方案。

2.2、修改root用户密码

使用alter user语句修改用户密码:

ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';

2.3、创建普通用户并授权(开发人员或者DBA使用的比较频繁)

初学者可以先忽略授权这一步,使用root用户将基本功练扎实。还没入门,就没这头皮发麻的授权模式给弄崩溃了,哈哈。

授权命令GRANT,撤销权限命令REVOKE。创建用户并授权参考官方文档:https://dev.mysql.com/doc/refman/8.0/en/roles.html

创建角色:CREATE ROLE命令

CREATE ROLE 'app_developer', 'app_read', 'app_write';

授予角色权限:GRANT命令

GRANT ALL ON app_db.* TO 'app_developer';
GRANT SELECT ON app_db.* TO 'app_read';
GRANT INSERT, UPDATE, DELETE ON app_db.* TO 'app_write';

创建用户:CREATE USER命令

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';

授权给创建的用户:GRANT命令

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';

你还可以在my.ini或者my.cnf配置文件中指定设置:

[mysqld]
mandatory_roles='role1,role2@localhost,r3@%.example.com'

同样可以在命令模式下使用SET命令设置:

SET PERSIST mandatory_roles = 'role1,role2@localhost,r3@%.example.com';

检查角色dev1的权限,检查权限比较多,我就不一一列举。详情可以参考官方文档。

mysql> SHOW GRANTS FOR 'dev1'@'localhost';
+-------------------------------------------------+
| Grants for dev1@localhost                       |
+-------------------------------------------------+
| GRANT USAGE ON *.* TO `dev1`@`localhost`        |
| GRANT `app_developer`@`%` TO `dev1`@`localhost` |
+-------------------------------------------------+

创建用户并授权,授权全部权限:

CREATE USER 'old_app_dev'@'localhost' IDENTIFIED BY 'old_app_devpass';
GRANT ALL ON old_app.* TO 'old_app_dev'@'localhost';

锁定用户:锁定:LOCK,盲猜解锁就是UNLOCK

ALTER USER 'old_app_dev'@'localhost' ACCOUNT LOCK;

授权给新的开发账号权限,授权部分权限:

CREATE USER 'new_app_dev1'@'localhost' IDENTIFIED BY 'new_password';
GRANT 'old_app_dev'@'localhost' TO 'new_app_dev1'@'localhost';

以上提供官方文档进行参考,与其东找找西找找,不如翻阅官方文档更直接更准确。咱缺的不是学习的途径,而是缺乏学习的方法。

3、测试创建用户

3.1、创建普通用户并授权远程登录

创建一个普通用户test

mysql> CREATE USER 'test'@'localhost' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)

授予用户test在本地(localhost)的权限,只给查询权限(SELECT),授权所有(ALL)

mysql> GRANT SELECT ON *.* TO test@'localhost';
Query OK, 0 rows affected (0.01 sec)

3.2、给root用户授权

创建root用户授权给所有IP都能登录,以及修改密码缓存认证方式

mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'Mysql@123456';
mysql> GRANT ALL ON *.* TO root@'%';
mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Mysql@123456';
mysql> flush privileges;

在第三方工具中验证登录结果,在localhost下可以登录成功

网络异常,图片无法展示
|

目前只给了查询(select)权限,验证插入(insert)权限

mysql> insert into study values(7,'美柑');
ERROR 1142 (42000): INSERT command denied to user 'test'@'localhost' for table 'study'

这是在SQLyog工具下进行验证的,建议初学者多在命令行窗口下进行练习,熟能生巧。

网络异常,图片无法展示
|

3.2、授权root用户远程登录,MySQL8.0授权方式

用户授权,在MySQL8.0版本中变得更加严格,以前MySQL5.6或者5.7版本中可以执行授权的方式有了变化。经过个人亲测,操作如下。

MySQL8.0授权方式,记得使用flush privileges刷新权限

mysql> CREATE USER 'root'@'%' IDENTIFIED BY 'Mysql@123456'; -- 第一步创建用户
mysql> GRANT ALL ON *.* TO root@'%'; -- 第二步授权
mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'Mysql@123456'; -- 第三步修改密码验证方式
mysql> flush privileges; -- 第四步刷新权限

修改密码认证方式(8.0默认使用的是sha2算法缓存认证),第一种解决方案如下,这只是其中一种解决方案,亲测有效

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

第二种解决方案:在my.ini或者my.cnf配置文件加入如下配置,重启服务并加载配置文件。经过测试没有生效,似乎没有读取到配置文件,但奇怪的是我设置的3307端口和默认存储引擎以及编码格式是生效的。(在官网看到的解决方案

[mysqld]
default_authentication_plugin=mysql_native_password

MySQL8.0官方文档默认设置的认证缓存算法是caching_sha2_password

ALTER USER user(用户) IDENTIFIED WITH caching_sha2_password BY 'password';

MySQL8.0之前的授权方式(5.6或者5.7都支持这种方式授权

GRANT ALL PRIVILEGES ON *.* TO '你的用户名'@'你的IP地址' IDENTIFIED BY '设置的密码' WITH GRANT OPTION;

示例:授权root户,所有IP都可连接

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;

刷新权限

flush privileges;

4、如何高效的使用自带官方文档

登录到MySQL8,指定3307端口,或者使用默认端口登录。

mysql -uroot -p -P 3307
mysql -uroot -p

使用帮助命令,以? create contents形式查找系统帮助命令。

? create contents;
? create user;
? create database;
? create table;
? select;
? insert;
? update;
? delete;
URL: https://dev.mysql.com/doc/refman/8.0/en/select|insert|update|delete.html

在使用本地的帮助文档时,你会发现系统自动提示了官方文档的地址 https://dev.mysql.com/doc。

示例:查询创建表的帮助命令? create table只展示了一部分内容。

mysql> ? create table
Name: 'CREATE TABLE'
Description:
Syntax:
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
    (create_definition,...)
    [table_options]
    [partition_options]
data_type:
    (see https://dev.mysql.com/doc/refman/8.0/en/data-types.html)
index_type:
    USING {BTREE | HASH}
index_option: {
    KEY_BLOCK_SIZE [=] value
  | index_type
 ...
}
URL: https://dev.mysql.com/doc/refman/8.0/en/create-table.html
  • Name:查看的帮助命令名称
  • Description:描述
  • Syntax:示例
  • data_type:支持的数据类型
  • index_type:可以使用的索引类型

我只列举了部分进行说明,更详细的可以自己测试。

在创建用户、数据库以及建表和字段全部采取的大写,因为在Linux和Unix下对大写敏感的,并不是MySQL本身对大小写敏感。

1、创建数据库

CREATE DATABASE TEST;
USE TEST;

2、创建表,可以通过ENGINE指定表的存储引擎,mysql5.6以及之后的版本默认为InnoDB存储引擎。

CREATE TABLE STUDY(
    ID INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
    NAMES VARCHAR(64) NOT NULL
)ENGINE=MyISAM;

3、插入数据

INSERT INTO STUDY VALUES(1,'mysql目前最新版本msyql8.0.28');

4、查询数据

SELECT * FROM STUDY;

5、修改数据

UPDATE STUDY S SET S.NAMES='mysql默认的存储引擎是InnoDB' WHERE S.ID=1;

6、删除全部数据

DELETE FROM STUDY;

至此基本的创建用户、创建数据库、增删改查都会使用了。

四、MySQL连接工具

做了超链接,方便去官网获取。

  • phpMyAdmin
  • MYSQL workbench
  • SQLyog

推荐几个比较常用的工具:phpMyAdminSQLyogMySQL Workbench、Navicat可视化工具进行连接操作。工具的使用是其次的,更重要的在于对MySQL命令语句的运用。

tips:包含了SQLyog,还整理了部分安装包以及MySQL官方提供的sakilaworld示例哟!

链接: https://pan.baidu.com/s/11gIlZKxoTG5BCCcoXdVJRg 提取码: ntu7

给出一个使用Navicat逆向生成的示例数据库world的模型:

网络异常,图片无法展示
|

如果真的要使用到建物理模型:推荐你学习Sybase PowerDesigner设计工具的使用,而且需要了解关系数据库设计遵循的三范式。现在数据库设计最多满足3NF,普遍认为范式过高,虽然具有对数据关系更好的约束性,但也导致数据关系表增加而令数据库IO更易繁忙,原来交由数据库处理的关系约束现更多在数据库使用程序中完成。

五、MySQL之JDBC

1、官方connector-j

MySQL8.0的maven安装JDBC:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-installing-maven.html

JDBC连接驱动管理:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-usagenotes-connect-drivermanager.html

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
// Notice, do not import com.mysql.cj.jdbc.*
// or you will have problems!
public class LoadDriver {
    public static void main(String[] args) {
        try {
            // The newInstance() call is a work around for some
            // broken Java implementations
            Class.forName("com.mysql.cj.jdbc.Driver").newInstance();
        } catch (Exception ex) {
            // handle the error
        }
    }
}
Connection conn = null;
...
try {
    conn = DriverManager.getConnection("jdbc:mysql://localhost/test?" +
                                   "user=root&password=123456");
    // Do something with the Connection
   ...
} catch (SQLException ex) {
    // handle any errors
    System.out.println("SQLException: " + ex.getMessage());
    System.out.println("SQLState: " + ex.getSQLState());
    System.out.println("VendorError: " + ex.getErrorCode());
}

2、JDBC测试连接MySQL8.0数据库

2.1、maven配置

设置pom.xml配置文件,使用MySQL最新的版本8.0.28进行连接测试。maven的镜像仓库,可以使用阿里的镜像源地址。

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version>
    <exclusions>
        <exclusion>
            <groupId>com.google.protobuf</groupId>
            <artifactId>protobuf-java</artifactId>
        </exclusion>
    </exclusions> 
</dependency>

2.2、编写Java代码

使用编辑器sts(Spring Tool Suite4或者IDEA)

创建普通的maven项目或者springboot项目,然后配置pom.xml。

目的:使用纯JDBC测试,或者ORM框架mybatis、JPA、或者hibernate都行,最终达到对数据库进行最基本的增删改查。

package com.example.demo.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestConnMySQL8 {
  public static void main(String[] args) throws ClassNotFoundException, SQLException {  
    TestSQLConnMySQL();
  }
  private static final Logger log = LoggerFactory.getLogger(TestConnMySQL8.class);
  //初始化参数
  static Connection conn = null;
  static PreparedStatement ps = null;
  static ResultSet rs = null;
  /**
   * @throws SQLException
   * @throws ClassNotFoundException
   */
  private static void TestSQLConnMySQL() throws SQLException, ClassNotFoundException {
    try {
      Class.forName("com.mysql.cj.jdbc.Driver");
      /**
       * 1.获取连接参数url,username,password,默认端口是3306
       * MySQL:url ="jdbc:mysql://127.0.0.1:3306/test";
       */
      /** MySQL拼接url **/
      String url = "jdbc:mysql://192.168.245.147:3306/TEST?useUnicode=true&characterEncoding=utf-8";
      String username = "root";
      String password = "Mysql@123456";
      //获取连接
      conn = DriverManager.getConnection(url, username, password);
      if(null != conn) {
        log.info("connect database success...");
      }else {
        log.error("connect database failed...");
      }
      //查询数据库
      String sql = "SELECT * FROM STUDY";
      // 3.通过preparedStatement执行SQL
      ps = conn.prepareStatement(sql);  
      // 4.执行查询,获取结果集
      rs = ps.executeQuery();
      // 5.遍历结果集,前提是你的数据库创建了表以及有数据
      while (rs.next()) {
        //对应数据库表中字段类型Int使用getInt,varchar使用getString
        System.out.println("ID:" + rs.getInt("ID"));
        System.out.println("姓名:" + rs.getString("NAMES"));
      }
    } finally {
      // 6.关闭连接 释放资源
      rs.close();
      ps.close();
      conn.close();
    }
  }
}

在sts编辑工具连接并返回测试结果

网络异常,图片无法展示
|

总结

以上就是本次MySQL8.0.28安装与使用的全部内容,希望能对你的工作与学习有所帮助。感觉写的好,就拿出你的一键三连。在公众号上更新的可能要快一点,目前还在完善中。能看到这里的,都是帅哥靓妹。如果感觉总结的不到位,也希望能留下您宝贵的意见,我会在文章中进行调整优化。

网络异常,图片无法展示
|

原创不易,转载也请标明出处和作者,尊重原创。不定期上传到github或者gitee。认准龙腾万里sky,如果看见其它平台不是这个ID发出我的文章,就是转载的。MySQL系列文章:《MySQL开发篇,存储引擎的选择真的很重要吗?》已经上传至github和gitee仓库SQL-study。个人github仓库地址,一般会先更新PDF文件,然后再上传markdown文件。如果访问github太慢,可以使用gitee进行克隆。

tips:使用hexo搭建的静态博客也会定期更新维护。

作者:龙腾万里sky

转载地址https://www.cnblogs.com/cnwangk/p/15860688.html

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
47 16
|
14天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
64 14
|
11天前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
51 7
|
16天前
|
安全 关系型数据库 MySQL
Windows Server 安装 MySQL 8.0 详细指南
安装 MySQL 需要谨慎,特别注意安全配置和权限管理。根据实际业务需求调整配置,确保数据库的性能和安全。
89 9
|
22天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
48 3
|
22天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
54 3
|
22天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
72 2
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
227 15
|
29天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
1月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。