0

我在为 product_data 建立索引时遇到问题,我收到此错误:(ps 我最近更改了主机,我通过 Shell 重新索引作为 adminhtml 超时)

Product Flat Data 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
(`britwear_magento`.<result 2 when explaining filename '#sql-55fda_1226f51'>,
CONSTRAINT `FK_CAT_PRD_FLAT_2_ENTT_ID_CAT_PRD_ENTT_ENTT_ID` 
FOREIGN KEY (`entity_id`) REFERENCES `catalog_product_e)' 
in /home2/britwear/public_html/magento/lib/Zend/Db/Statement/Pdo.php:228
Stack trace:

#0 /home2/britwear/public_html/magento/lib/Zend/Db/Statement/Pdo.php(228): PDOStatement->execute(Array)
#1 /home2/britwear/public_html/magento/lib/Varien/Db/Statement/Pdo/Mysql.php(110): Zend_Db_Statement_Pdo->_execute(Array)
#2 /home2/britwear/public_html/magento/lib/Zend/Db/Statement.php(300): Varien_Db_Statement_Pdo_Mysql->_execute(Array)
#3 /home2/britwear/public_html/magento/lib/Zend/Db/Adapter/Abstract.php(479): Zend_Db_Statement->execute(Array)
#4 /home2/britwear/public_html/magento/lib/Zend/Db/Adapter/Pdo/Abstract.php(238): Zend_Db_Adapter_Abstract->query('ALTER TABLE `ca...', Array)
#5 /home2/britwear/public_html/magento/lib/Varien/Db/Adapter/Pdo/Mysql.php(389): Zend_Db_Adapter_Pdo_Abstract->query('ALTER TABLE `ca...', Array)
#6 /home2/britwear/public_html/magento/lib/Varien/Db/Adapter/Pdo/Mysql.php(327): Varien_Db_Adapter_Pdo_Mysql->query('ALTER TABLE `ca...')
#7 /home2/britwear/public_html/magento/lib/Varien/Db/Adapter/Pdo/Mysql.php(2548): Varien_Db_Adapter_Pdo_Mysql->raw_query('ALTER TABLE `ca...')
#8 /home2/britwear/public_html/magento/app/code/core/Mage/Catalog/Model/Resource/Product/Flat/Indexer.php(806): Varien_Db_Adapter_Pdo_Mysql->addForeignKey('FK_CAT_PRD_FLAT...', 'catalog_product...', 'entity_id', 'catalog_product...', 'entity_id', 'CASCADE', 'CASCADE')
#9 /home2/britwear/public_html/magento/app/code/core/Mage/Catalog/Model/Resource/Product/Flat/Indexer.php(125):  Mage_Catalog_Model_Resource_Product_Flat_Indexer->prepareFlatTable(2)
#10 /home2/britwear/public_html/magento/app/code/core/Mage/Catalog/Model/Resource/Product/Flat/Indexer.php(115): Mage_Catalog_Model_Resource_Product_Flat_Indexer->rebuild('2')
#11 /home2/britwear/public_html/magento/app/code/core/Mage/Catalog/Model/Product/Flat/Indexer.php(73): Mage_Catalog_Model_Resource_Product_Flat_Indexer->rebuild(NULL)
#12 /home2/britwear/public_html/magento/app/code/core/Mage/Catalog/Model/Product/Indexer/Flat.php(303): Mage_Catalog_Model_Product_Flat_Indexer->rebuild()
#13 /home2/britwear/public_html/magento/app/code/core/Mage/Index/Model/Process.php(166): Mage_Catalog_Model_Product_Indexer_Flat->reindexAll()
#14 /home2/britwear/public_html/magento/app/code/core/Mage/Index/Model/Process.php(194): Mage_Index_Model_Process->reindexAll()
#15 /home2/britwear/public_html/magento/shell/indexer.php(158): Mage_Index_Model_Process->reindexEverything()
#16 /home2/britwear/public_html/magento/shell/indexer.php(198): Mage_Shell_Compiler->run()
#17 {main}

我假设我必须删除 phpMyAdmin 中的外键约束,但我不确定在哪里?

4

2 回答 2

1

尝试选择两个表并修复可能的问题。您可以从某些表中删除 id,或者您可以添加特定的 id,以便您现在可以重新索引并在下一次删除。你能解释一下你做了什么来得到这个错误吗?

于 2011-11-23T07:12:33.377 回答
1

删除表catalog_product_flat_(删除平面目录)

php shell/indexer.php reindexall(有magento索引

于 2012-04-24T06:54:01.760 回答