Magento 1.7.0.2重新索引产品属性错误

时间:2014-02-18 00:24:21

标签: php mysql magento magento-1.7

在Magento 1.7.0.2中重新索引产品属性后,我们收到以下错误:

Product Attributes index process unknown error:
exception 'PDOException' with message 'SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`xxdbnamexx`.`mage_catalog_product_index_eav`, CONSTRAINT `FK_CAT_PRD_IDX_EAV_ENTT_ID_CAT_PRD_ENTT_ENTT_ID` FOREIGN KEY (`entity_id`) REFERENCES `mage_catalog_product_entity` (`entity_id)' in /home/xxxxxxxxx/public_html/lib/Zend/Db/Statement/Pdo.php:228
Stack trace:
#0 /home/xxxxxxxxx/public_html/lib/Zend/Db/Statement/Pdo.php(228): PDOStatement->execute(Array)
#1 /home/xxxxxxxxx/public_html/lib/Varien/Db/Statement/Pdo/Mysql.php(110): Zend_Db_Statement_Pdo->_execute(Array)
#2 /home/xxxxxxxxx/public_html/lib/Zend/Db/Statement.php(300): Varien_Db_Statement_Pdo_Mysql->_execute(Array)
#3 /home/xxxxxxxxx/public_html/lib/Zend/Db/Adapter/Abstract.php(479): Zend_Db_Statement->execute(Array)
#4 /home/xxxxxxxxx/public_html/lib/Zend/Db/Adapter/Pdo/Abstract.php(238): Zend_Db_Adapter_Abstract->query('INSERT INTO `ma...', Array)
#5 /home/xxxxxxxxx/public_html/lib/Varien/Db/Adapter/Pdo/Mysql.php(419): Zend_Db_Adapter_Pdo_Abstract->query('INSERT INTO `ma...', Array)
#6 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Resource/Abstract.php(179): Varien_Db_Adapter_Pdo_Mysql->query('INSERT INTO `ma...')
#7 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Resource/Helper/Mysql4.php(48): Mage_Index_Model_Resource_Abstract->insertFromSelect(Object(Varien_Db_Select), 'mage_catalog_pr...', Array, false)
#8 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Resource/Abstract.php(153): Mage_Index_Model_Resource_Helper_Mysql4->insertData(Object(Mage_Catalog_Model_Resource_Product_Indexer_Eav_Source), Object(Varien_Db_Select), 'mage_catalog_pr...', Array, false)
#9 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Resource/Abstract.php(113): Mage_Index_Model_Resource_Abstract->insertFromTable('mage_catalog_pr...', 'mage_catalog_pr...', false)
#10 /home/xxxxxxxxx/public_html/app/code/core/Mage/Catalog/Model/Resource/Product/Indexer/Eav/Abstract.php(54): Mage_Index_Model_Resource_Abstract->syncData()
#11 /home/xxxxxxxxx/public_html/app/code/core/Mage/Catalog/Model/Resource/Product/Indexer/Eav.php(185): Mage_Catalog_Model_Resource_Product_Indexer_Eav_Abstract->reindexAll()
#12 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Indexer/Abstract.php(143): Mage_Catalog_Model_Resource_Product_Indexer_Eav->reindexAll()
#13 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Process.php(209): Mage_Index_Model_Indexer_Abstract->reindexAll()
#14 /home/xxxxxxxxx/public_html/app/code/core/Mage/Index/Model/Process.php(255): Mage_Index_Model_Process->reindexAll()
#15 /home/xxxxxxxxx/public_html/shell/indexer.php(158): Mage_Index_Model_Process->reindexEverything()
#16 /home/xxxxxxxxx/public_html/shell/indexer.php(198): Mage_Shell_Compiler->run()
#17 {main}

任何人都可以提供任何帮助吗?

1 个答案:

答案 0 :(得分:0)

错误消息显示您尝试执行的操作违反了mage_catalog_product_index_eavmage_catalog_product_entity之间的外键约束。

这意味着mage_catalog_product_index_eav表中的entity_ids没有出现在mage_catalog_product_entity表中。这可能是因为mage_catalog_product_entity中的某些entity_id为空。

也可能是因为mage_catalog_product_index_eav试图引用的记录根本不存在。在这种情况下,您可以从mage_catalog_product_index_eav删除引用记录。

在任何情况下,您都必须弄清楚违规记录的确切含义。查看Magento 1.6.2 cant not reindex product flat data上的第一个答案,获取有关如何执行此操作的指示。 (这不是完全相同的问题,因为他们正在处理平面数据,但我认为仍然有用。)