linux的mysql数据库的由于权限问题看不到mysql库user表

来源:互联网 发布:js 左边 菜单栏 缩进 编辑:程序博客网 时间:2024/04/28 15:42
今天在安装mysql数据库后,想开启远程连接,发现查询不到了mysql数据库自带的mysql数据库,是由于用户的权限问题导致,解决办法如下:

第一种情况

[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 `user` VALUES ('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 `user` VALUES ('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' 来设置密码了。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72

第二种情况

1.首先停止mysql服务:service mysqld stop2.加参数启动mysql:/usr/bin/mysqld_safe --skip-grant-tables & 然后就可以无任何限制的访问mysql了3.root用户登陆系统:mysql -u root -p mysql4.切换数据库:use mysql5.显示所有的表: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,可以解决问题了
0 0
原创粉丝点击