一、原因:
把MySQL的密码也改成'YES',就连不上了。密码设置时不能使用明文
USE mysql
UPDATE uesr SET password= 'YES' where user='root' AND host='localhost';
FLUSH PRIVILEGES;
退出控制台后就再进不去了。
mysql -u root -p
mysql -h localhost -u root -p
都不行,出现错误:
"Host 'localhost' is not allowed to connect to this MySQL server."
二、方法
首先停止mysql服务:
sc stop mysql
然后:
mysqld --skip-grant-tables
另开一个终端,继续
mysqlcheck --check-upgrade --all-databases --auto-repair
然后再输入
mysql
就可以进入MySQL控制台了。这样进去以后使用SELECT语句会发现密码使用的是明文:'YES',哈哈,我真是个疯子。
三、问题
以上进去控制台后并不能执行账户维护工作。正确的方法为:
然后使用以下语句将密码还原为 root 的 HASH 值:
UPDATE user SET password= PASSWORD('YES') where user='root' AND host='localhost';
然后,mysqld --skip-grant-tables 这个命令似乎只可以在本地运行。
如果mysql服务无法正常停止,使用命令:mysqladmin -u root shutdown
把MySQL的密码也改成'YES',就连不上了。密码设置时不能使用明文
USE mysql
UPDATE uesr SET password= 'YES' where user='root' AND host='localhost';
FLUSH PRIVILEGES;
退出控制台后就再进不去了。
mysql -u root -p
mysql -h localhost -u root -p
都不行,出现错误:
"Host 'localhost' is not allowed to connect to this MySQL server."
二、方法
首先停止mysql服务:
sc stop mysql
然后:
mysqld --skip-grant-tables
另开一个终端,继续
mysqlcheck --check-upgrade --all-databases --auto-repair
然后再输入
mysql
就可以进入MySQL控制台了。这样进去以后使用SELECT语句会发现密码使用的是明文:'YES',哈哈,我真是个疯子。
三、问题
以上进去控制台后并不能执行账户维护工作。正确的方法为:
如上进入控制台后,选中要操作的数据库:
use mysql;
UPDATE user SET password= PASSWORD('YES') where user='root' AND host='localhost';
然后,mysqld --skip-grant-tables 这个命令似乎只可以在本地运行。
如果mysql服务无法正常停止,使用命令:mysqladmin -u root shutdown