找回密码
 注册账号

QQ登录

只需一步,快速开始

《泰拉瑞亚下载-1.4.2.3版》 泰拉瑞亚服务器 - MOD模组下载

入驻泰拉战网 新手指引 - 升级 - 师徒

泰拉瑞亚合成表 泰拉卡牌 - 泰拉江湖 - 泰拉刺客

联系泰拉开发组👈进入 积分市场 - 房产交易 - 水晶获取

查看: 3443|回复: 0

Mysql 错误1051的解决办法

[复制链接]

466

主题

48

回帖

0

广播

论坛版主

积分
200
泰拉
0
水晶
0
铜钥匙
0
银钥匙
0
金钥匙
0

【江湖新秀】【宝剑回鞘】【泰拉达人】【奥运选手】

发表于 2020-6-15 15:21:16 | 显示全部楼层 |阅读模式
利用”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数据库已经不存在了,被我们删除了。

您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

QQ|友链申请|Archiver|手机版|小黑屋|游芯沙盒 ( 陕ICP备11006283号-1 )

GMT+8, 2024-11-21 17:11 , Processed in 0.100322 second(s), 34 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表