当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL数据库的root口令恢复方法总结

MYSQL
Linux学习教程:不同版本Mysql安装
MySql教程:两个表之间更新数据
WIndows系统下安装mysql-noinstall版本
PageCookery:基于Php+Mysql架构国产的微博客
MYSQL教程:MYSQL外键的应用
MYSQL教程:my.cnf缓存优化
MYSQL教程:Explain用法
MySQL的mysqldump工具导入导出数据
mysql proxy读写分离脚本的问题
MYSQL教程:学习MYSQL存储过程
Got error 28 from storage engine
用mysqldump导出Trigger问题解决方法
MYSQL的MASTER到MASTER的主主循环同步
MYSQL教程:MYSQL查询优化
MYSQL教程:了解MYSQL临时表
MYSQL教程:mysqldump使用说明
MYSQL教程:Show命令使用说明
MYSQL教程:MYSQL数据表随机数的取出
Webjx收集10个漂亮的Joomla!网站设计实例
phpBB 3.0.6 RC1简单介绍和下载

MYSQL 中的 MySQL数据库的root口令恢复方法总结


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 92 ::
收藏到网摘: n/a

方法一

1. 下载MySQL源码分发包,不用区分操作系统,我们需要的东西是一样的;


2. 重命名自己的mysql的data目录下的mysql文件夹为oldmysql;

3. 将源码包中data目录下的mysql目录复制到你的mysql的data目录下;

4. 重新启动mysql,现在mysql的授权关系同全新安装的一样,空密码登陆,然后自行调整授权;

5. 打开oldmysql这个库检查到底出现了什么问题 ;

6. 如果有备份对系统中原有的数据库进行完整性检测,以免被人修改。

方法二

1. 向mysqld server发送kill命令关掉mysqld server(不是 kill -9),存放进程ID的文件通常在MYSQL的数据库所在的目录中。

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

你必须是Linux的root用户或者是你所运行的SERVER上的同等用户,才能执行这个操作;

killall -TERM mysqld

2. 使用`--skip-grant-tables’ 参数来启动 mysqld;

shell>mysqld_safe --skip-grant-tables &

/ bin/safe_mysqld --skip-grant-tables &


3. 使用`mysql -h hostname mysql’命令登录到mysqld server ,用grant命令改变口令。你也可以这样做:

`mysqladmin -h hostname -u user password ’new password’’

其实也可以用

use mysql; update user set password =password(’yourpass’) where user=’root’

来做到;

shell>mysqladmin -u root flush-privileges password "newpassword"

>use mysql

>update user set password=password("new_pass") where user="root";

>flush privileges;

4. 载入权限表:

`

mysqladmin -h hostname flush-privileges’

或者使用SQL命令

`FLUSH PRIVILEGES’

当然,在这里,你也可以重启mysqld。