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

本文介绍了两种解决MySQL数据库用户权限不足的方法,包括暂时禁用权限表、修改用户权限等步骤,帮助用户顺利进行数据库管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在安装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 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,可以解决问题了

 

<think>好的,我需要帮助用户解决在Linux上创建MySQL数据库后,Navicat无法看到该数据库问题。根据用户提供的引用内容,我需要结合这些信息来找出可能的原因和解决方案。 首先,用户提到在Linux上创建了数据库,但Navicat不显示。可能的原因包括权限问题、网络配置、MySQL绑定地址设置、防火墙阻止访问等。我需要逐一分析这些可能性。 根据引用[1],提到Error 10061,通常与连接被拒绝有关,可能因为MySQL服务未运行或防火墙阻止。用户已经创建了数据库,所以可能服务是运行的,但需要检查绑定地址是否正确。引用[3]中提到需要注释掉bind-address = 127.0.0.1,这样MySQL才能接受远程连接。所以这一步可能是关键。 然后,引用[4]指出主机地址可能填写错误,用户可能误用了服务器的内网IP而非公网IP,或者端口未正确开放。此外,数据库用户的权限可能没有授予远程访问,只允许本地连接。需要检查用户的权限设置,使用GRANT命令赋予远程访问权限。 另外,防火墙设置可能阻止了3306端口,需要确保端口开放,如使用ufw或iptables配置。同时,宝塔面板可能管理了防火墙,用户需要确认在宝塔中添加了MySQL端口的放行规则。 还有可能Navicat连接时使用了SSH通道,但配置不正确导致的问题,如引用[2]中提到的SSH连接错误。但用户的问题可能更基础,比如主机地址、端口、权限等。 总结可能的解决步骤: 1. 确认MySQL绑定地址设置为0.0.0.0,允许远程连接。 2. 检查数据库用户的权限是否允许从远程主机访问。 3. 确保防火墙开放了MySQL端口(默认3306)。 4. 确认Navicat连接使用正确的主机地址、端口、用户名和密码。 5. 检查宝塔面板或云服务商的安全组规则是否允许外部访问。 需要将这些步骤详细列出,并参考提供的引用内容,特别是关于修改bind-address和用户权限的部分。同时提醒用户注意主机地址是否为公网IP,以及端口是否正确。</think>### Linux上创建MySQL数据库后Navicat不显示的解决方案 #### 1. 检查MySQL绑定地址配置 MySQL默认绑定本地地址$127.0.0.1$,需修改为$0.0.0.0$允许远程访问: ```bash sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf ``` 注释或修改以下行: ```ini # bind-address = 127.0.0.1 # 修改后重启MySQL服务[^3] ``` 重启服务: ```bash sudo systemctl restart mysql ``` #### 2. 检查用户远程访问权限 创建用户时需指定远程访问权限: ```sql CREATE USER 'username'@'%' IDENTIFIED BY 'password'; -- %示允许所有IP GRANT ALL PRIVILEGES ON database.* TO 'username'@'%'; FLUSH PRIVILEGES; ``` 若已存在用户,更新权限: ```sql UPDATE mysql.user SET host='%' WHERE user='username'; FLUSH PRIVILEGES; ``` #### 3. 验证防火墙设置 开放MySQL默认端口$3306$: ```bash sudo ufw allow 3306/tcp # Ubuntu系统 sudo firewall-cmd --add-port=3306/tcp --permanent # CentOS系统 ``` 云服务器需在控制台安全组添加规则(如阿里云、AWS)[^4]。 #### 4. 检查Navicat连接参数 - **主机**:填写服务器公网IP(非内网IP) - **端口**:确认与MySQL配置一致(默认$3306$) - **用户名/密码**:使用具有远程权限的账户 #### 5. 验证数据库可见性 在Navicat中执行SQL查询: ```sql SHOW DATABASES; -- 确认数据库已创建 SELECT user,host FROM mysql.user; -- 验证用户权限 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值