测试环境

  删除前

     mysql> select user,host,password from mysql.user;
+------+-----------+-------------------------------------------+
| user | host | password |
+------+-----------+-------------------------------------------+
| root | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root | jinch | |
| root | 127.0.0.1 | |
| root | ::1 | |
| test | 10.0.0.% | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
    

删除root用户

 mysql> drop user root@'localhost';

为了测试,把其他root相关都删除了,命令就不一一展示了,显示结果。

   删除后

     mysql> select user,host from mysql.user;
+------+-----------+
| user | host |
+------+-----------+
| test | localhost |
+------+-----------+
1 row in set (0.00 sec)

退出再登陆

     [root@db01 ~]# mysql -uroot -p
Enter password:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

  现在已经无法登陆了,之前误删过一次。。。无奈那会儿不知道如何解决,就只能重装了,但是,经过一段时间的学习,发现并不是没有解决办法的。

解决方法

  

  首先,关闭数据库

service mysqld stop

用安全模式设置开启免密登陆

  

mysqld_safe --skip-grant-tables --skip-networking &

--skip-grant-tables  关闭连接层的验证模块
     --skip-networking    关闭远程连接数据库(只允许本地登陆,可设置防火墙达到相同效果)

[root@jinch ~]# mysqld_safe --skip-grant-tables
     181010 16:57:03 mysqld_safe Logging to '/usr/local/mysql/data/jinch.err'.
     181010 16:57:04 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data

  然后使用mysql命令就可以直接进入数据库
    进入之后,使用insert 命令重新插入表
     

 mysql> insert into user(user,host,password,ssl_type,ssl_cipher,x509_issuer,x509_subject) values('root','localhost',PASSWORD('123'),'','','','');
   

PASSWORD大写的原因:在mysql中密码都是密文的,所以这里是调用一个函数,将明文加密成密文。
    然后退出重启一下数据库就可以重新使用账号密码登录了

     mysql> quit
Bye
[root@db01 ~]# /etc/init.d/mysqld restart
[root@db01 ~]# mysql -uroot -p123
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    

mysql>  --这边就放一部分啦,
  误删root用户无法登陆的解决就到这里啦

 

注意 如果成功后访问出现1142没有权限问题:

    

    mysql> select user,password from mysql.user;
ERROR 1142 (42000): SELECT command denied to user 'root'@'localhost' for table 'user'

看了一下报错信息,权限不够。。。那就是没有权限了
     退出数据库并且关闭mysql服务
     mysql> quit
     Bye
     安全模式启动mysql,root用户登录

     [root@db01 ~]# mysqld_safe --skip-grant-tables &
[root@db01 ~]# mysql -uroot -p123 mysql

  切换数据库&查看表信息中的root用户的localhost权限

 mysql> use mysql;
Database changed
mysql> show tables;
+---------------------------+
| Tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| event |
| func |
| general_log |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| innodb_index_stats |
| innodb_table_stats |
| ndb_binlog_index |
| plugin |
| proc |
| procs_priv |
| proxies_priv |
| servers |
| slave_master_info |
| slave_relay_log_info |
| slave_worker_info |
| slow_log |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
28 rows in set (0.00 sec) mysql> select * from user where user='root' and host='localhost'\G;
*************************** 1. row ***************************
Host: localhost
User: root
Password: *23AE809DDACAF96AF0FD78ED04B6A265E05AA257
Select_priv: N
Insert_priv: N
Update_priv: N
Delete_priv: N
Create_priv: N
Drop_priv: N
Reload_priv: N
Shutdown_priv: N
Process_priv: N
File_priv: N
Grant_priv: N
References_priv: N
Index_priv: N
Alter_priv: N
Show_db_priv: N
Super_priv: N
Create_tmp_table_priv: N
Lock_tables_priv: N
Execute_priv: N
Repl_slave_priv: N
Repl_client_priv: N
Create_view_priv: N
Show_view_priv: N
Create_routine_priv: N
Alter_routine_priv: N
Create_user_priv: N
Event_priv: N
Trigger_priv: N
Create_tablespace_priv: N
ssl_type:
ssl_cipher:
x509_issuer:
x509_subject:
max_questions: 0
max_updates: 0
max_connections: 0
max_user_connections: 0
plugin: mysql_native_password
authentication_string: NULL
password_expired: N
1 row in set (0.00 sec) ERROR:
No query specified

这里发现全部都是N ,表示root用户本地登陆没有权限
 修改root用户的localhost权限
    01.

update mysql.user set Grant_priv='Y',Super_priv='Y' where user='root';

flush privileges;

grant all on *.* to 'root'@'localhost';

下面这写行不用输入,上面命令的实质就是下面 的操作

mysql> update user set `Insert_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Update_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Delete_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Create_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Drop_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Reload_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Shutdown_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Process_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `File_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Grant_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `References_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Index_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Alter_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Show_db_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Super_priv` ='Y',`Create_tmp_table_priv` = 'Y' where user='root'' and host='localhost';

     mysql> update user set `Lock_tables_priv` ='Y' where user='root' and host='localhost';  

     mysql> update user set `Execute_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Repl_slave_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Repl_client_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Create_view_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Show_view_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Create_routine_priv` ='Y' where user='root' and host='localhost'';

     mysql> update user set `Alter_routine_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Create_user_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Event_priv` ='Y' where user='root' and host='localhost';

     mysql> update user set `Trigger_priv` ='Y' where user='root' and host='localhost';

     mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

退出&重启&登陆

     mysql> quit
Bye
[root@jinch ~]# /etc/init.d/mysqld restart
Shutting down MySQL.. SUCCESS!
Starting MySQL.. SUCCESS!
[root@jinch ~]# mysql -uroot -p123

切换库

     mysql> use mysql;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed

#####  查看表信息

   mysql> select * from user\G;
*************************** 1. row ***************************
Host: localhost
User: root
Password: *23AE809DDACAF96AF0FD78ED04B6A265E05AA257
Select_priv: Y
Insert_priv: Y
Update_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
Alter_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
Event_priv: Y
Trigger_priv: Y
Create_tablespace_priv: N
ssl_type:
ssl_cipher:
x509_issuer:
x509_subject:
max_questions: 0
max_updates: 0
max_connections: 0
max_user_connections: 0
plugin: mysql_native_password
authentication_string: NULL
password_expired: N
1 row in set (0.01 sec) ERROR:
No query specified

权限已经基本都有了
测试一下

mysql> create database jinc;
Query OK, 1 row affected (0.00 sec) mysql> select user,host from mysql.user;
+------+-----------+
| user | host |
+------+-----------+
| root | localhost |
+------+-----------+
1 row in set (0.00 sec) mysql> drop database jinc;
Query OK, 0 rows affected (0.00 sec)

MySQL误删root用户导致无法登陆解决方法的更多相关文章

  1. mysql误删root用户或者忘记root密码解决方法

    解决方法一: 到其他安装了Mysql的服务器(前提是要知道该服务器上Mysql的root用户密 码),打开[Mysql的安装目录/var/mysql],将其中的user.frm.user.MYD.us ...

  2. mysql误删root用户

    在操作mysql时误删除root用户,如何进行恢复 在安装hive时候误删除root用户,存在的用户没有权限,解决方法如下. 1.首先在/etc/my.cnf文件中 mysqlID下面添加 skip- ...

  3. 无法给MySQL root用户修改密码的解决方法

    本人编译安装完MySQL数据库,想给root用户修改密码,结果无法修改,并且报错,报错大概信息如下: mysqladmin: connect to server at 'localhost' fail ...

  4. MySQL使用root用户授权出现错误ERROR 1045 (28000) at line 2: Access denied for user 'root'@'%' (using password: YES)解决办法

    参考:https://blog.csdn.net/open_data/article/details/42873827 使用MySQL的root用户登录出现错误提示 ERROR 1045 (28000 ...

  5. MysqL的root用户不允许远程连接

    原文:MysqL的root用户不允许远程连接 今天程序报了异常:java.sql.SQLException: Access denied for user 'root'@'RJB-Z' (using ...

  6. 第三篇 ubuntu下,mysql 的root用户密码忘了怎么办?

    好长一段时间没有使用ubuntu了,今天进来玩玩,结果连mysql的root用户密码都忘记了.就上网找了一下,发现如下解决办法,试了一下,可行!记录在此,环境问题,是需要注意的. Ubuntu Ser ...

  7. mysql的root用户被删除, MySQL 服务无法启动 1067错误

    本文出现的问题有: 1, root(localhost) 用户被删除; 2, 在关闭mysql服务过后, 无法启动,出现1067错误; 我使用的mysql版本为5.6; mysql的安装路径: C:\ ...

  8. yum安装mysql后root用户的临时密码

    1.查看root用户临时随机密码 yum 安装mysql后,无法通过空密码登录数据库,如下: [root@ mysql]# mysql -u root -p Enter password: ERROR ...

  9. MySQL重置root用户密码的方法

    本教程适用于采用Win2003.WinXP操作系统的迅美VPS和云主机产品. 当管理员忘记MySQL密码怎么办?屡次输入密码,仍然提示错误,网站无法正常运行,数据库也无法管理,管理员束手无策. 网站程 ...

随机推荐

  1. Android Hander、Looper、Message三者之间的联系

    1.首先Looper.prepare()在本线程中保存一个Looper实例,然后该实例中保存一个MessageQueue对象:因为Looper.prepare()在一个线程中只能调用一次,所以Mess ...

  2. Java集合类总结 (四)

    PriorityQueue类 优先队列不管你按照什么顺序插入元素,出队列的时候元素都是按顺序输出的.也就是每次调用remove的时候,都返回当前队列中最小的元素.然后队列中的元素不是维持排序状态的,如 ...

  3. DataType--时间类型

    SQL SERVER 存储时间的方式和存放浮点数的方式类似,存放时按照一定公式算出一个数值,存放到页面,在读取时按照公式求算出时间值,再按照默认或指定的时间格式展示给用户. 如果存放DATETIME数 ...

  4. Ubuntu下vi编辑器不听话

    编辑文件/etc/vim/vimrc.tiny,将“compatible”改成“nocompatible”非兼容模式: 并添加一句:set backspace=2 

  5. windows下go编码转换问题

    github上有两个package做编码转换,都是基于iconv,用到了cgo,在linux下没有问题,在windows下用,非常麻烦.采用mingw安装libiconv也不行,一直提示找不到libi ...

  6. 巧用Scrum与Kanban

    本文来自网易云社区 文\屈鹏飞 在互联网行业的项目管理实践中,敏捷和精益一直是大家所提倡的思想,其中Scrum和Kanban方法作为即敏捷又精益的典型代表,许多PM都在研究,笔者近期也在学习和实施Sc ...

  7. dos窗口运行java文件需要jar依赖

    执行java文件时候,有些里面依赖了java之外的jar,这是识别不到的,运行java命令的时候,带上jar路径: java -cp .;jar路径(加上jar名字)  java文件名 例:java ...

  8. Docker Community Edition 镜像使用帮助

    1.什么是Docker 容器技术 在计算机的世界中,容器拥有一段漫长且传奇的历史.容器与管理程序虚拟化 (hypervisor virtualization,HV)有所不同,管理程序虚拟化通过中间层将 ...

  9. gym 102082B dp

    和51nod1055 一样: #include<iostream> #include<cstdio> #include<algorithm> #include< ...

  10. Codeforces Round #175 (Div. 2) A~D 题解

    A.Slightly Decreasing Permutations Permutation p is an ordered set of integers p1,  p2,  ...,  pn, c ...