MySQL:怎样重新设置一个忘记的口令,这求解

MySQL:怎样重新设置一个忘记的口令,这求解,第1张

kill `cat /mysql-data-directory/hostname.pid`

使用--skip-grant-tables选项重启mysqld。

用mysql -h hostname mysql连接mysqld服务器并且用一条GRANT命令改变口令。也可以用mysqladmin -h hostname -u user password 'new password' 进行。

如果你忘记了MySQL的root用户的口令,你可以用下列过程恢复它。

通过发送一个kill(不是kill -9)到mysqld服务器来关闭mysqld服务器。pid 被保存在一个.pid文件中,通常在MySQL数据库目录中:

kill `cat /mysql-data-directory/hostname.pid`

你必须是一个UNIX root用户或运行服务器的相同用户做这个。

使用--skip-grant-tables选项重启mysqld。

用mysql -h hostname mysql连接mysqld服务器并且用一条GRANT命令改变口令。见7.26 GRANT和REVOKE句法。你也可以用mysqladmin -h hostname -u user password 'new password' 进行。

用mysqladmin -h hostname flush-privileges或用SQL命令FLUSH PRIVILEGES来装载权限表

因为我只有一个用户:select user,host from user时

| root | localhost |

后来我用update user set password=PASSWORD('')可是我用错了,我用成了:update user set password=''

突然退出后,再登录就无法登录了,真是没法啊.

按以上的步骤进行到mysqld --skip-grant-tables后无报错,但mysql还是没有启动,所以无法用后面的mysql登录,因为此时3306都没有打开.无可赖何之下只得重装它(教训!).

cmd下切换到

mysql

安装目录例d:/mysql/bin

前提:mysql用户root密码为空.

输入mysql

-u

root

mysql

mysql>

状态下输入

update

user

set

password=password('新密码')

where

user='root'回显query

ok,

0

rows

affected

(0.00

sec)

rows

matched:

2

changed:

0

warnings:

0

mysql>

状态下输入

flush

privileges回显query

ok,

0

rows

affected

(0.00

sec)

mysql>

状态下输入

quit退出sql注意每个命令后都要加上一个分号

""

mysql

才开始执行该行命令

而第二个指令会让已载入记忆体的

mysql

系统资料库更新

重起mysql

.

在更新

root

密码后,以后要与

mysql

连接的方法为


欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zaji/5907307.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存