mysql误删root用户或者忘记root密码解决方法
2011-05-15 01:51
1126 查看
解决方法一:
到其他安装了Mysql的服务器(前提是要知道该服务器上Mysql的root用户密码),打开【Mysql的安装目录/var/mysql】,将其中的user.frm、user.MYD、user.MYI三个文件拷贝到出问题服务器的【Mysql的安装目录/var/mysql】目录中。然后重启服务器。
解决方法二:
修改你的my.ini或my.cnf文件,在 [mysqld] 节下加入下面一行
skip-grant-tables
然后保存并重启 MySQL 服务。 下面你就可以以任何用户名密码登陆数据库了。
(1)如果是误删了root用户,则使用下面的语句创建root用户:
insert into user set Host='localhost',User='root',Password=Password('111111'),select_priv='y', insert_priv='y',update_priv='y', Alter_priv='y',delete_priv='y',create_priv='y',drop_priv='y',reload_priv='y',shutdown_priv='y',Process_priv='y',file_priv='y',grant_priv='y',References_priv='y',index_priv='y',create_user_priv='y',show_db_priv='y',super_priv='y',create_tmp_table_priv='y',Lock_tables_priv='y',execute_priv='y',repl_slave_priv='y',repl_client_priv='y',create_view_priv='y',show_view_priv='y',create_routine_priv='y',alter_routine_priv='y';
(2)如果是忘记了root用户的密码,则使用下面的语句修改root密码:
update user set Password=Password('111111') where User='root';
mysql误删root用户
1、先结束mysqld进程
#killall mysqld进入mysql
#/usr/local/mysql/bin/mysql
不加载grant_tables而进入mysql
#mysqld_safe –skip-grant-tables &
mysql> use mysql
Database changed
mysql> select * from user;
Empty set (0.00 sec)
mysql> insert into user set user='root',ssl_cipher=”,x509_issuer=”,x509_subject=”;
(增加root用户的表)
Query OK, 1 row affected, 3 warnings (0.00 sec)
(这时可能会提示某字段如ssl_cipher无默认值, 只要加上,ssl_cipher=”; 其字段如有提示依次添加就OK了)
update user set Host='localhost',select_priv='y', insert_priv='y',update_priv='y', Alter_priv='y',delete_priv='y',create_priv='y',drop_priv='y',reload_priv='y',shutdown_priv='y',Process_priv='y',file_priv='y',grant_priv='y',References_priv='y',index_priv='y',create_user_priv='y',show_db_priv='y',super_priv='y',create_tmp_table_priv='y',Lock_tables_priv='y',execute_priv='y',repl_slave_priv='y',repl_client_priv='y',create_view_priv='y',show_view_priv='y',create_routine_priv='y',alter_routine_priv='y',create_user_priv='y' where user='root';
(这里面是修改root用户的权限)
mysql> quit;
2、带权限正常启动mysql
#service mysqld start
3、使用root用户登录(如果有phpadmin就直接用root空密码登录再修改密码或权限就可以了)
#mysql -u root -p
mysql> update user set password=password('123456′) where user='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges;
mysql> quit
到其他安装了Mysql的服务器(前提是要知道该服务器上Mysql的root用户密码),打开【Mysql的安装目录/var/mysql】,将其中的user.frm、user.MYD、user.MYI三个文件拷贝到出问题服务器的【Mysql的安装目录/var/mysql】目录中。然后重启服务器。
解决方法二:
修改你的my.ini或my.cnf文件,在 [mysqld] 节下加入下面一行
skip-grant-tables
然后保存并重启 MySQL 服务。 下面你就可以以任何用户名密码登陆数据库了。
(1)如果是误删了root用户,则使用下面的语句创建root用户:
insert into user set Host='localhost',User='root',Password=Password('111111'),select_priv='y', insert_priv='y',update_priv='y', Alter_priv='y',delete_priv='y',create_priv='y',drop_priv='y',reload_priv='y',shutdown_priv='y',Process_priv='y',file_priv='y',grant_priv='y',References_priv='y',index_priv='y',create_user_priv='y',show_db_priv='y',super_priv='y',create_tmp_table_priv='y',Lock_tables_priv='y',execute_priv='y',repl_slave_priv='y',repl_client_priv='y',create_view_priv='y',show_view_priv='y',create_routine_priv='y',alter_routine_priv='y';
(2)如果是忘记了root用户的密码,则使用下面的语句修改root密码:
update user set Password=Password('111111') where User='root';
mysql误删root用户
1、先结束mysqld进程
#killall mysqld进入mysql
#/usr/local/mysql/bin/mysql
不加载grant_tables而进入mysql
#mysqld_safe –skip-grant-tables &
mysql> use mysql
Database changed
mysql> select * from user;
Empty set (0.00 sec)
mysql> insert into user set user='root',ssl_cipher=”,x509_issuer=”,x509_subject=”;
(增加root用户的表)
Query OK, 1 row affected, 3 warnings (0.00 sec)
(这时可能会提示某字段如ssl_cipher无默认值, 只要加上,ssl_cipher=”; 其字段如有提示依次添加就OK了)
update user set Host='localhost',select_priv='y', insert_priv='y',update_priv='y', Alter_priv='y',delete_priv='y',create_priv='y',drop_priv='y',reload_priv='y',shutdown_priv='y',Process_priv='y',file_priv='y',grant_priv='y',References_priv='y',index_priv='y',create_user_priv='y',show_db_priv='y',super_priv='y',create_tmp_table_priv='y',Lock_tables_priv='y',execute_priv='y',repl_slave_priv='y',repl_client_priv='y',create_view_priv='y',show_view_priv='y',create_routine_priv='y',alter_routine_priv='y',create_user_priv='y' where user='root';
(这里面是修改root用户的权限)
mysql> quit;
2、带权限正常启动mysql
#service mysqld start
3、使用root用户登录(如果有phpadmin就直接用root空密码登录再修改密码或权限就可以了)
#mysql -u root -p
mysql> update user set password=password('123456′) where user='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges;
mysql> quit
您可能感兴趣的文章:
- windows下mysql忘记root密码的解决方法
- Mysql的Root密码忘记,查看或修改的解决方法(图文介绍)
- 忘记mysql数据库root用户密码重置方法[图文]
- linux mysql忘记密码的多种解决或Access denied for user ''root''@''localhost''
- 强制修改mysql的root密码的六种方法分享(mysql忘记密码)
- windows环境中mysql忘记root密码的解决方法详解
- 忘记MySQL的root密码该怎么办
- Mysql 5.7 忘记root密码或重置密码的详细方法
- linux下mysql的root密码忘记的解决方法
- Mac下MySQL5.7忘记root密码的解决方法
相关文章推荐
- mysql误删root用户或者忘记root密码解决方法
- mysql误删root用户或者忘记root密码解决方法
- mysql误删root用户或者忘记root密码解决方法
- Mac下忘记Mysql的root用户密码的解决方法
- mysql误删除root用户或者忘记root密码时的解决办法
- Blog5@linux用户及其权力管理、超户(root)密码忘记的解决方法
- Linux中忘记超级用户root密码的解决方法
- Linux系统root用户忘记密码解决方法
- 【MySQL】忘记root用户密码详细解决方法
- RHCE_LAB(3)Linux(RHEL5)root用户忘记密码的解决方法
- fedora 忘记普通用户或root密码的解决方法
- linux下root修改密码 或者忘记root密码解决方法
- Linux下MySQL中root用户密码忘记的解决方法
- MySQL超级用户(root)密码忘记重置,附N多解决方法!
- RHCE_LAB(3)Linux(RHEL5)root用户忘记密码的解决方法
- 如何解除Oracle 帐号锁定(the account is locked)或者Oracle system用户忘记密码的解决方法
- mysql误删除root用户或者忘记root密码时的解决办法(转载)
- MySQL忘记密码 或者误删除root用户有效解决办法
- RHCE_LAB(3)Linux(RHEL5)root用户忘记密码的解决方法