繁体   English   中英

Magento - 基表 core_file_storage 不存在

[英]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 如果错误仍然存在,解决问题的最干净的方法如下:

  1. Go 到 SYSTEM>CONFIGURATION>ADVANCED>SYSTEM 并将“Storage Configuration for Media”切换到“Database”。 单击同步。 等待同步过程完成或超时(可能取决于您的设置)。 表“core_directory_storage”已创建并填满。 单击 SAVE CONFIG(不确定此步骤是否必要,但无论如何都要执行)。
  2. 如果同步过程超时,您可能会在 Magento 管理员中看到有关重大错误的通知“同步媒体存储时发生错误。”。 没关系,因为在下一步中,我们将恢复到基于文件的媒体存储。
  3. 在第 1 步中调整的相同设置中,切换回“文件系统”并再次单击“同步”。 单击 SAVE CONFIG(不确定此步骤是否必要,但无论如何都要执行)。
  4. 现在 go 到您的数据库管理器(例如 PHPMyAdmin)并使用 DELETE FROM core_directory_storage删除最近创建的表中的所有行。

您的表格丢失错误现在消失了。

缺少的表可以由系统自动创建,您只需 go 即可:

System > Configuration
System (Advanced menu) > "Storage Configuration for Media" tab

并选择将媒体文件存储在DB中,然后在同步完成后将其关闭。 这将创建缺少的表。

这个问题发生在我身上,我必须给媒体文件夹 777 权限。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM