|
利用”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数据库已经不存在了,被我们删除了。
|
|