linux的mysql数据库的由于权限问题…

今天在安装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表中,修改相应权限,比如(此种插入方法会报错,BLOB字段不为空,但是这个字段无法通过手动生成):

 

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

      然后通过管理工具新建'localhost','root' 这样的用户,直接插入数据库表无法插入空的BLOB字段,所以需要通过建用户的方式实现。

 

  操作完成后,将两个ssh连接都关闭,然后再重新连接一个ssh,启动mysql,service mysqld start,然后用mysql命令连接mysql数据库

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

  密码为空。

  [如果此时还连接不上,再重启一下mysql就好了,service mysqld restart]。

  然后就可以用 [root@localhost ~]#mysqladmin -uroot password 'newpassword' 来设置密码了。

也可以用 : update user set authentication_string = password('root') where user = 'root'; (5.7版本的mysql没有password字段了)
mysql> SELECT 1;
ERROR 1820 (HY000): You must SET PASSWORD before executing this statement 
mysql> SET PASSWORD = PASSWORD('new_password');
Query OK, 0 rows affected (0.01 sec) 
 mysql> SELECT 1; 
+---+ 
| 1 |
+---+ 
| 1 | 
+---+ 
1 row in set (0.00 sec)

第二种情况

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,可以解决问题了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值