ERROR 1054 (42S22): Unknown column 'plugin' in 'mysql.user'

1.版本

1)操作系统

 cat /etc/issue
Red Hat Enterprise Linux Server release 5.5 (Tikanga)
Kernel \r on an \m

 cat /proc/version
Linux version 2.6.32-504.el6.x86_64 (mockbuild@c6b9.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) ) #1 SMP Wed Oct 15 04:27:16 UTC 2014

2)mysql数据库版本

mysql --version
mysql  Ver 14.14 Distrib 5.6.26, for linux-glibc2.5 (x86_64) using  EditLine wrapper


2.问题描述

  在创建一个新用户的时候报如下错误:

mysql> grant file on *.* to 'shao'@'%' identified by 'root';
ERROR 1054 (42S22): Unknown column 'plugin' in 'mysql.user'
  与此同时error log中记录了如下错误:

2015-12-11 14:46:11 13795 [Warning] Did not write failed 'grant file on *.* to 'shao'@'%' identified by 'root'' into binary log while granting/revoking privileges in databases.


3.问题分析

mysql> grant file on *.* to 'shao'@'%' identified by 'root';
ERROR 1054 (42S22): Unknown column 'plugin' in 'mysql.user'
##通过上面的报错我们可以看到,报的是plugin字段在mysql.user表中不存在,就是因为这个导致了我们添加用户报如上错误。那为什么mysql.user表中会缺少字段呢?(这种问题一般出现在通过mysql升级过程中)。我对比了一下另一套正常的数据库(5.6.26)发现mysql.user 有43个字段,而出现问题的数据库只有39个字段。

   后来想起来是有一次为了恢复我一套5.1的数据时,把5.1的mysqldump备份文件拿到了这套库上来恢复了。去查了一下当前5.1版本的数据库的mysql.user果然是39个字段(对比每个字段同出问题的库是一致的)。那么现在问题就清楚了,因为现在库中使用的是5.1版本的mysql.user表。(那应该还有其他的系统表也是有问题的)


4.问题解决

  居然问题清楚了,那解决问题就简单了,使用如下命令去修复表

mysql_upgrade --protocol=tcp -P3306 -p 

  修复完成后继续重启数据库实例,再次执行grant命令

mysql> grant file on *.* to 'shao'@'%' identified by 'root';
Query OK, 0 rows affected (0.04 sec)

mysql> 
##命令执行成功






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

渔夫数据库笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值