ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

解决mysql:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using pas

2020-04-06 22:58:09  阅读:260  来源: 互联网

标签:1045 NO 密码 user mysql validate password root


1 现象

mysql -u root -p

错误:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO/YES)
2 linux系统:

在配置文件my-default.cnf或my.cnf下

[mysqld]下添加skip-grant-tables;因为此方法无效,所以找到了以下方法

为了加强安全性,MySQL5.7为root用户随机生成了一个密码,在error log中,关于error log的位置,如果安装的是RPM包,则默认是/var/log/mysqld.log。

所以在/var/log/找到文件mysqld.log

用命令:vi 打开

进入命令模式

查找生成的随机密码

输入:/temporary password

可以看到:

A temporary password is generated for root@localhost: <你要找的临时密码>
所以就可以以此密码登陆‘root’用户了
mysql -u root -p 回车
要输入密码:<上面找到的临时密码>
输入:use mysql;
进入mysql后就是修改密码了
如果直接输入:update user set authentication_string=password('新密码,例如:123456') where user='root';
则:ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
这个意思是说你设置的密码‘123456’不符合安全规则(1.必须含有数字,小写或大写字母,特殊字符;
2.最小长度为8)


必须修改两个全局参数
首先,修改validate_password_policy参数的值
set global validate_password_policy=0;
这样就去除了规则 1,只有长度限制了
接下来修改参数 validate_password_length
mysql> select @@validate_password_length;#查看参数值
+----------------------------+
| @@validate_password_length |
+----------------------------+
| 8 |
+----------------------------+

set global validate_password_length=1;

mysql> select @@validate_password_length;#查看参数值
+----------------------------+
| @@validate_password_length |
+----------------------------+
| 4 |
+----------------------------+
只要设置的值小于4都为4。
这样就可以修改简单的密码了
update user set authentication_string=password('密码:root') where user='root';
flush privileges;
退出:quit
重启服务:service mysqld restart
进入mysql
mysql -u root -proot
成功!
3 windows:

进入mysql安装目录,复制my-default.ini,命名为my.ini


编辑my.ini
在[mysqld]下添加skip-grant-tables
保存。

重启mysql:1、net stop mysql 2、net start mysql
进入mysql
mysql -u root -p
不用输入密码,直接回车
输入use mysql
修改root的密码
update user set authentication_string=password('新密码') where user='root';
flush privileges;
退出:quit
再次重启mysql:1、net stop mysql 2、net start mysql
测试是否成功就是是否登陆成功咯。
mysql -u root -p<新密码>
完成!

标签:1045,NO,密码,user,mysql,validate,password,root
来源: https://www.cnblogs.com/forforever/p/12650282.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有