解决mysql:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO/YES)
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<新密码>
完成!
相关文章
- mycat 链接mysql提示ERROR 3009 (HY000): java.lang.IllegalArgumentExceptio解决方式
- mysql解决乱码问题
- 【MySQL】Can't get stat of './mysql/slow_log.CSV' (Errcode: 2)
- 【异常】ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock
- 如何解决MySQL连接超时关闭
- 总结--解决 mysql 中文乱码
- 连接Mysql提示Can’t connect to local MySQL server through socket的解决方法
- MYSQL错误解决:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
- ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (
- 解决mysql使用GTID主从复制错误问题
- ERROR 1130 Host is not allowed to connect to this MySQL server 问题解决
- 解决MYSQL ERROR 1045 (28000)问题
- 数据库基础之Mysql(3)mysql删除历史binlog
- mysql 有报错 ERROR! MySQL is not running, but lock file (/var/lock/subsys/mysql) exists
- 重置密码解决MySQL for Linux错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
- 连接Mysql提示Can’t connect to local MySQL server through socket的解决方法
- paip.解决 数据库mysql增加列 字段很慢添加字段很慢
- paip.提升性能--- mysql 建立索引 删除索引 很慢的解决.
- 成功解决Building wheel for dlib (setup.py) ... error ERROR: Command errored out with exit status 1:
- 【高可用MySQL解决方案】centos7配置mysql主从复制
- 关于appium踩坑 :Encountered internal error running command: Error: Cannot verify the signature of (已解决)
- 上Mysql com.mysql.jdbc.StatementImpl$CancelTask内存泄漏问题和解决方法
- MySQL Study之--Mysql无法启动“mysql.host”
- mysql select into outfile默认文件保存路径是C:ProgramDataMySQLMySQL Server 8.0Data
- 安全测试===Mysql 注入技巧学习 MySQL注入技巧(2)
- _mysql.c(42) : fatal error C1083: Cannot open include file: 'config-win.h':问题的解决 mysql安装python
- 【常见 Error & Bug】Vivado仿真报错 ERROR: [XSIM 43-3322] 解决方法