MySQL8的root帐号授权

Posted 程序员老刘

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL8的root帐号授权相关的知识,希望对你有一定的参考价值。

执行下面的命令MySQL8会报错:

 grant all privileges on db_name.* to \'root\'@\'%\'
  ### Cause: java.sql.SQLSyntaxErrorException: Access denied for user \'root\'@\'%\' to database \'db_name\'

解决办法:

SELECT `User`, `Grant_priv` FROM `mysql`.`user` WHERE `User` = \'root\';
  UPDATE `mysql`.`user` SET `Grant_priv` = \'Y\' WHERE `User` = \'root\';
  grant all privileges on *.* to \'root\'@\'%\';
  FLUSH PRIVILEGES;

MySQL8的root远程授权

CREATE USER \'root\'@\'%\' IDENTIFIED WITH mysql_native_password BY \'密码\';
  GRANT ALL ON *.* TO \'root\'@\'%\';
  FLUSH PRIVILEGES;

 

Mysql重置root密码遇到的坑(忘记密码)

1、原理

通过配置参数“skip_grant_tables”在mysql启动时跳过grant_tables(授权表),从而通过命令来充值root帐号的密码

2、方式

首先需要停止mysql服务

(1)在my.ini文件的[mysqld]块下增加“skip_grant_tables”,然后重启mysql服务,再以管理员权限打开cmd执行一些列命令重置密码

步骤如下:

A、找到my.ini文件(右击mysql服务找到可执行文件路径,从所在的目录或其它层级目录搜索),在[mysqld]块下增加“skip_grant_tables”

B、重启mysql服务

C、以管理员权限打开cmd命令窗口,执行mysql -uroot –p直接回车不用输入密码

D、选择数据库:use mysql

E、更新root的密码:update user set authentication_string=password(\'新密码\') where user=\'root\' and Host=\'localhost\'

F、刷新权限:flush privileges

G、退出:quit

H、重新登录:mysql -uroot -p提示输入密码,这时输入密码才能登录

I、回到 my.ini 配置文件移除“skip_grant_tables”,再重启mysql

 

(2)直接通过命令指定参数“skip_grant_tables”启动mysql,再执行命令修改密码(与1的步骤除了指定跳过授权表参数的方式不同以外,其它都一样)

A、在第一个cmd窗口执行 mysqld --defaults-file="C:\\ProgramData\\MySQL\\MySQL Server 5.7\\my.ini" --skip-grant-tables   ---注意路径(以你的实际情况为准)

其它步骤同上

参考:

Windows下MySQL5.7 root 密码重置

https://blog.csdn.net/hey_yf/article/details/80024706

Windows下Mysql5.7忘记root密码的解决方法

https://www.cnblogs.com/yuwentims/p/9172463.html

3、遇到的坑

同过修改my.ini的方式配置“skip_grant_tables”再保存千万要注意编码的格式“ANSI”

(1)用Notepad++将修改了my.ini的配置

(2)重启mysql服务,就启动不了(超时),通过命令去执行接下来的操作会报“ERROR 1045 (28000): Access denied for user \'ODBC\'@\'localhost\' (using password: NO)”的错误

(3)第一想到的是去百度,无果后从系统事件日志开始着手,发现了一些莫名其它的错误(其实部分是系统里其它程序的错误日志):

A、首先根据关键字看到的是“服务 MySQL57 意外停止。这发生了 7 次。”并没卵用

B、然后就在这个错误的隔壁找其它错误 “应用程序-特定 权限设置并未向在应用程序容器 不可用 SID (不可用)中运行的地址 LocalHost (使用 LRPC) 中的用户 NT AUTHORITY\\LOCAL SERVICE SID (S-1-5-19)授予针对 CLSID ”像这种不明不白的错误头脑一发热并没有多想,然后就是百度解决并没有屁用

解决方式:

https://www.cnblogs.com/ibgo/p/3550674.html

http://www.ntxz.net/?p=580

解决了这个日志,但是对mysql并没影响,现在才明白找错了方向

(4)于是将所有的事件日志清除,重启computer

(5)终于发现了一条这样的错误 “mysql 启动报错--发现系统错误2,系统找不到指定的文件”

解决方式:

https://blog.csdn.net/Marvel__Dead/article/details/63262641?locationNum=4&fps=1

解决了报错,mysql服务可以启动了

接着执行重置的命令,终于报了一条有意义的错“Found option without preceding group in config file:XXX; Fatal error in defaults handling.“,找到了原来是my.ini编码惹得祸!

 

改成ANSI,一切就顺利了…

参考:

MySQL报错: Found option without preceding group in config file:XXX; Fatal error in defaults handling.

https://blog.csdn.net/life_android/article/details/56512606

4、注意

(1)确保服务里只有一个MySql

 

以上是关于MySQL8的root帐号授权的主要内容,如果未能解决你的问题,请参考以下文章

mysql8 修改root远程连接权限

MySQL8.0版本安装后授权

mysql8版本之后的授权用户远程登录

Navicat11.1连接Mysql8.0报错1251的解决办法

Mysql8.0数据库远程管理

MySQL授权root