magento管理员错误:SQLSTATE [42S02]:找不到基表或视图:1146表'sinergi_luki.captcha_log'不存在

时间:2012-05-25 01:24:25

标签: php magento-1.5 magento

我的管理页面有问题。登录管理员后,突然显示错误信息..

SQLSTATE [42S02]:未找到基表或视图:1146表' sinergi_luki.captcha_log'不存在

是因为我将我的magento 1.5.0.1迁移到新服务器但在新服务器中我安装了magento 1.7.0.0 ..?或为什么?给我一个解决方案的家伙。谢谢!

5 个答案:

答案 0 :(得分:7)

Mage_Captcha是从Magento 1.7.0开始提供的新核心模块,安装脚本似乎命名不正确。

将app / code / core / Mage / Captcha / sql / captcha_setup / install-1.7.0.0.0.php重命名为mysql4-install-1.7.0.0.0.php,然后从缓存管理中刷新缓存存储。

我不确定Magento开发人员是否正在为不需要“mysql4”的安装脚本实施新标准 - '前缀,但如果是这样,当我升级到1.7.0.2时它没有工作,所以重命名这个文件就可以了。

答案 1 :(得分:5)

使用以下代码创建一个sql文件,并将其导入数据库。

-- Server version   5.5.9

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `captcha_log`
--

DROP TABLE IF EXISTS `captcha_log`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `captcha_log` (
  `type` varchar(32) NOT NULL COMMENT 'Type',
  `value` varchar(32) NOT NULL COMMENT 'Value',
  `count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT 'Count',
  `updated_at` timestamp NULL DEFAULT NULL COMMENT 'Update Time',
  PRIMARY KEY (`type`,`value`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Count Login Attempts';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `captcha_log`
--

LOCK TABLES `captcha_log` WRITE;
/*!40000 ALTER TABLE `captcha_log` DISABLE KEYS */;
/*!40000 ALTER TABLE `captcha_log` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

-- Dump completed on 2012-07-10 14:41:53

答案 2 :(得分:0)

可悲的是,除了以下情况之外,没有任何神奇的答案:下次正确迁移Magento。

新服务器上的系统具有引用自定义数据库表 sinergi_luki的代码。这张表没有从旧版本到新服务器。它也不是基础magento安装的一部分。据谷歌翻译,sinergi这个词是印度尼西亚人的协同作用,Luki似乎是一个印度尼西亚名字,所以我的猜测是以前的开发人员构建了一些自定义功能而不包括数据库迁移。

您应找到旧数据库,导出此表,然后将其拉回到新系统中。除此之外你就是SOL。

祝你好运。

答案 3 :(得分:0)

sinergi_luki是对magento安装的根文件夹名称的引用,仅此而已。

我们从1.4.2升级到1.6到1.6到1.7.0.1(ssh升级)没有问题,除了登录时出现的错误:

  

SQLSTATE [42S02]:未找到基表或视图:1146表'apezooc_magento.captcha_log'不存在

再次按输入,错误消失,我们进入管理部分。

答案 4 :(得分:0)

由于验证码模块安装脚本未运行/执行而导致问题。 要解决此问题,请从'captcha_setup'表中删除'core_resource'的条目 或者

delete FROM core_resource where code='captcha_setup';   

并刷新浏览器