linux的mysql权限错误致使看不到mysql数据库

转载 http://www.blogjava.net/jelver/archive/2015/03/22/423715.htmlhtml

第一种状况java

[root@localhost ~]# mysql -uroot -p123

  Welcome 
to the MySQL monitor. Commands end with ; or \g.

  Your MySQL connection id 
is 7

  Server version: 
5.0.77 Source distribution

  Type 
'help;' or '\h' for help. Type '\c' to clear the buffer.

  mysql
>show databases;

  
+--------------------+

  
| Database |

  
+--------------------+

  
| information_schema |

  
| test |

  
+--------------------+

  只显示这个两个数据库,看不到mysql数据库

  解决方法:

  此问题其实是用户没有权限:

  
1. 关闭mysql,service mysqld stop

  
2. 启动mysql: mysqld_safe --skip-grant-tables

  
3. 再打开一个ssh链接服务器,进行mysql操做

  
[root@localhost ~]#mysql

  Welcome 
to the MySQL monitor. Commands end with ; or \g.

  Your MySQL connection id 
is 7

  Server version: 
5.0.77 Source distribution

  Type 
'help;' or '\h' for help. Type '\c' to clear the buffer.

  mysql
>show databases;

  在这个模式下是能够看到mysql数据库的。

  在数据库名mysql下的user表中,修改相应权限,好比:

  
INSERT INTO `userVALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);

  若是已经存在了host为localhost的记录,则先删除该记录,
delete from user where host='localhost';

  而后再进行INSERT 
INTO `userVALUES ('localhost','root','','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','','','','',0,0,0,0);

  操做。

  操做完成后,将两个ssh链接都关闭,而后再从新链接一个ssh,启动mysql,service mysqld start,而后用mysql命令链接mysql数据库

  
[root@localhost ~]#mysql -uroot -p

  密码为空。

  
[若是此时还链接不上,再重启一下mysql就行了,service mysqld restart]

  而后就能够用 
[root@localhost ~]#mysqladmin -uroot password 'newpassword' 来设置密码了。mysql


第二种状况sql

1.首先中止mysql服务:service mysqld stop
2.加参数启动mysql:/usr/bin/mysqld_safe --skip-grant-tables & 
而后就能够无任何限制的访问mysql了
3.root用户登录系统:mysql -u root -p mysql
4.切换数据库:use mysql
5.显示全部的表:show tables;
这里就能够访问表了
6.查看user表中root用户的localhost权限:select * from user where user='root' and host='localhost'
7.在显示的列表中显示:root用户的localhost的权限都是'N',表示root用户本地登录不具备权限
8.修改root用户的localhost权限:
  
update user set  
  `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'
  
where user='root' and host='localhost'        //这里需注意是否有这个条件的用户
  9.更新一下:flush privileges;
  10.而后从新启动下mysql,能够解决问题了
数据库

相关文章
相关标签/搜索