Mysql 错误1051的解决办法

转自:[url]http://www.liangkun.net/archives/391.html[/url]

利用”drop database message”删除mysql数据库中存在的”message”数据库,结果却提示“ERROR 1051<42S02>:Unknown table ‘message’”。删除存在的数据库为什么会报这个表相关错误呢?

这是由于Mysql的存储引擎store engine 不同造成的.

例如,最开始的engine=myisam,在此基础上建了A表,那么你现在要转成innodb的方式(开启了my.cnf下的innodb的参数)现在 如果再来 select A 表那么是会报不存在的,如果drop 的话会报 mysql error number 1051.这个问题该怎么处理呢? 先关掉my.cnf的innodb参数,然后重启mysql,这样A就可以select 了,把A表的backup 下来,drop 掉A表,然后再开启innodb参数,重起mysql,restore 刚才备份的脚本,这样就可以搞定了.

还有一种会报“ERROR 1051<42S02>:Unknown table ‘message’”可能的原因是:

mysql重新安装过,两次安装所用的默认存储引擎不一样。

其实我们上面图片操作的目的,是把mysql数据库的message这个库给删除掉,这个其实有一个临时的应急的方法,找到mysql的存放数据的data文件夹,在这个文件夹中找到message这个文件夹,把这个message文件夹全部删除掉。然后我们再回到mysql的命令行,执行“show databases”时发现这个message数据库已经不存在了,被我们删除了。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值