![](/img/trans.png)
[英]magento admin error : SQLSTATE[42S02]: Base table or view not found: 1146 Table 'sinergi_luki.captcha_log' doesn't exist
[英]Magento - Base Table core_file_storage Doesn't exist
当我查看 Magento 存储的错误日志时,它充满了这些错误:
[02-Jun-2011 13:49:12] PHP Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[42S02]: Base table or view not found: 1146 Table 'mysite_mysite.core_file_storage' doesn't exist' in /home/mysite/public_html/lib/Zend/Db/Statement/Pdo.php:228
Stack trace:
#0 /home/mysite/public_html/lib/Zend/Db/Statement/Pdo.php(228): PDOStatement->execute(Array)
#1 /home/mysite/public_html/lib/Zend/Db/Statement.php(300): Zend_Db_Statement_Pdo->_execute(Array)
#2 /home/mysite/public_html/lib/Zend/Db/Adapter/Abstract.php(479): Zend_Db_Statement->execute(Array)
#3 /home/mysite/public_html/lib/Zend/Db/Adapter/Pdo/Abstract.php(238): Zend_Db_Adapter_Abstract->query('SELECT `e`.* FR...', Array)
#4 /home/mysite/public_html/lib/Varien/Db/Adapter/Pdo/Mysql.php(337): Zend_Db_Adapter_Pdo_Abstract->query('SELECT `e`.* FR...', Array)
#5 /home/mysite/public_html/lib/Zend/Db/Adapter/Abstract.php(753): Varien_Db_Adapter_Pdo_Mysql->query(Object(Varien_Db_Select), Array)
#6 /home/mysite/public_html/app/code/core/Mage/Core/Model/Mysql4/File/Storag in /home/mysite/public_html/lib/Zend/Db/Statement/Pdo.php on line 234
有谁知道如何解决这个问题?
显然我还没有权限评论丹尼尔的答案,因此我将其添加为单独的答案。 用户 a1anm 也在 Magento 论坛上问了这个问题。 在那里,用户 Furnitureforyoultd 用两个不同的查询回答了这个问题。
首先,如果您还没有core_directory_storage,请运行:
CREATE TABLE `core_directory_storage` (
`directory_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`name` VARCHAR(255) NOT NULL DEFAULT '',
`path` VARCHAR(255) NOT NULL DEFAULT '',
`upload_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
`parent_id` INT(10) UNSIGNED NULL DEFAULT NULL,
PRIMARY KEY (`directory_id`),
UNIQUE INDEX `IDX_DIRECTORY_PATH` (`name`, `path`),
INDEX `parent_id` (`parent_id`),
CONSTRAINT `FK_DIRECTORY_PARENT_ID` FOREIGN KEY (`parent_id`) REFERENCES `core_directory_storage` (`directory_id`) ON UPDATE CASCADE ON DELETE CASCADE
) COMMENT='Directory storage' COLLATE='utf8_general_ci' ENGINE=InnoDB ROW_FORMAT=DEFAULT;
然后,运行:
CREATE TABLE `core_file_storage` (
`file_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`content` LONGBLOB NOT NULL,
`upload_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
`filename` VARCHAR(255) NOT NULL DEFAULT '',
`directory_id` INT(10) UNSIGNED NULL DEFAULT NULL,
`directory` VARCHAR(255) NULL DEFAULT NULL,
PRIMARY KEY (`file_id`),
UNIQUE INDEX `IDX_FILENAME` (`filename`, `directory`),
INDEX `directory_id` (`directory_id`),
CONSTRAINT `FK_FILE_DIRECTORY` FOREIGN KEY (`directory_id`) REFERENCES `core_directory_storage` (`directory_id`) ON UPDATE CASCADE ON DELETE CASCADE
) COMMENT='File storage' COLLATE='utf8_general_ci' ENGINE=InnoDB ROW_FORMAT=DEFAULT;
您不应该手动创建表格,只需检查您的媒体文件夹的权限(必须是777 )。
这是 Magento 内核中的问题,已添加到跟踪器并将修复。
但是,您应该知道,此错误的根源是您将 url 设置为不存在的文件。 Magento 内核的唯一问题是它抛出“致命错误”而不是显示 404 页面。
要解决此问题,请检查为什么您会收到 url 到不存在的文件。 必须正确设置媒体文件夹和子文件夹的权限 - 例如 777(否则不会在此处创建图像)或 url 格式错误。
这些表主要用于存储每个产品的上传图片。
此外,如果您的媒体默认存储设置为文件而不是数据库,magento 将尝试在文件系统中查找每个图像,但如果失败,它将尝试在数据库中查找。
请检查您的产品图片是否在媒体文件夹中(通常是 media/catalog/product/{az|0-9}/{az|0-9}/yourimage.jpg),否则,即使创建了这些表格,您也只会请求这些文件时收到 404 Not found 错误。
另外,请注意,如果您尝试在产品标题中使用非法字符,例如引号,这将导致 magento 尝试在其中创建包含此字符的缩略图。这将导致图像失败,magento 将尝试调用这些来自数据库的图像.. 如果您不使用数据库进行存储,您将看到 mysql 错误
如果您将使用文件系统存储,请确保您的 /media 目录设置为 777 并运行chmod -R o+w media
。 如果错误仍然存在,解决问题的最干净的方法如下:
core_directory_storage
删除最近创建的表中的所有行。您的表格丢失错误现在消失了。
缺少的表可以由系统自动创建,您只需 go 即可:
System > Configuration
System (Advanced menu) > "Storage Configuration for Media" tab
并选择将媒体文件存储在DB中,然后在同步完成后将其关闭。 这将创建缺少的表。
这个问题发生在我身上,我必须给媒体文件夹 777 权限。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.