MySQL:"怎样重新设置一个忘记的口令",这次误操作不管用了?
2007-11-11 16:14:12 来源:WEB开发网如果你忘记了MySQL(和PHP搭配之最佳组合)的root
用户的口令,你可以用下列过程恢复它。
kill `cat /MySQL(和PHP搭配之最佳组合)-data-directory/hostname.pid`
使用--skip-grant-tables
选项重启MySQL(和PHP搭配之最佳组合)d
。
用MySQL(和PHP搭配之最佳组合) -h hostname MySQL(和PHP搭配之最佳组合)
连接MySQL(和PHP搭配之最佳组合)d服务器并且用一条GRANT
命令改变口令。也可以用MySQL(和PHP搭配之最佳组合)admin -h hostname -u user password 'new password'
进行。
这是从baidu,google上能搜索到的,其实也是MySQL(和PHP搭配之最佳组合)手册中(8.9 怎样重新设置一个忘记的口令),所提到了,但我这次在windows 下却失败了...
如果你忘记了MySQL(和PHP搭配之最佳组合)的root
用户的口令,你可以用下列过程恢复它。
- 通过发送一个
kill
(不是kill -9
)到MySQL(和PHP搭配之最佳组合)d
服务器来关闭MySQL(和PHP搭配之最佳组合)d服务器。pid 被保存在一个.pid
文件中,通常在MySQL(和PHP搭配之最佳组合)数据库目录中:kill `cat /MySQL(和PHP搭配之最佳组合)-data-directory/hostname.pid`
你必须是一个UNIX
root
用户或运行服务器的相同用户做这个。 - 使用
--skip-grant-tables
选项重启MySQL(和PHP搭配之最佳组合)d
。 - 用
MySQL(和PHP搭配之最佳组合) -h hostname MySQL(和PHP搭配之最佳组合)
连接MySQL(和PHP搭配之最佳组合)d服务器并且用一条GRANT
命令改变口令。见7.26GRANT
和REVOKE
句法。你也可以用MySQL(和PHP搭配之最佳组合)admin -h hostname -u user password 'new password'
进行。 - 用
MySQL(和PHP搭配之最佳组合)admin -h hostname flush-privileges
或用SQL命令FLUSH PRIVILEGES
来装载权限表
这是从baidu,google上能搜索到的,其实也是MySQL(和PHP搭配之最佳组合)手册中(8.9 怎样重新设置一个忘记的口令),所提到了,但我这次在windows 下却失败了...
因为我只有一个用户:select user,host from user时
| root | localhost |
后来我用update user set password=PASSWORD(''); 可是我用错了,我用成了:update user set password='';
突然退出后,再登录就无法登录了,真是没法啊.
按以上的步骤进行到MySQL(和PHP搭配之最佳组合)d --skip-grant-tables后无报错,但MySQL(和PHP搭配之最佳组合)还是没有启动,所以无法用后面的MySQL(和PHP搭配之最佳组合)登录,因为此时3306都没有打开.
无可赖何之下只得重装它(教训!).
赞助商链接