在Magento中创建产品的完整性约束违规

时间:2012-10-28 21:05:54

标签: php sql magento exception product

我正在尝试从magento Frontend创建一个产品,但是当执行php代码时,我收到此错误:

SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`magento`.`catalog_product_entity`, CONSTRAINT `FK_CAT_PRD_ENTT_ATTR_SET_ID_EAV_ATTR_SET_ATTR_SET_ID` FOREIGN KEY (`attribute_set_id`) REFERENCES `eav_attribute_set` (`attribute_set_id`) ON DE)

我在这里找到:Create a product from PHP - Magento这应该是属性集ID的问题,但我尝试从eav_attribute_set表强制ID,然后使用函数:

Mage::getModel('catalog/config')->getAttributeSetId('catalog_product','Set_evento')

上面有这个函数但是带有“Default”值。没有什么变化。那么问题可能不是属性集ID?

这是我的代码:

$product = Mage::getModel('catalog/product');

$product->setSku(time());
$product->setName("Evento senza nome");
$product->setDescription("123");
$product->setShortDescription("1234");
$product->setPrice(0.00);
$product->setTypeId('virtual');
$attributeSetId = Mage::getModel('catalog/config')->getAttributeSetId('catalog_product','Set_evento');
$product->setAttributeSetId($attributeSetId); 
$product->setCategoryIds(array($cat_id)); 
$product->setVisibility(4); // catalog, search
$product->setStatus(1); // enabled

// assign product to the default website
$product->setWebsiteIds(array(Mage::app()->getStore(true)->getWebsite()->getId()));

// for stock
$stockData = $product->getStockData();
$stockData['qty'] = 1;
$stockData['is_in_stock'] = 1;
$product->setStockData($stockData);

$product->setCreatedAt(strtotime('now'));

Mage::app()->getStore()->setId(Mage_Core_Model_App::ADMIN_STORE_ID);

$product->save();

谢谢!

3 个答案:

答案 0 :(得分:2)

如果$attributeSetId成功返回有效身份证件,请检查您是否设置了有效Mage::getModel('catalog/config')->getAttributeSetId('catalog_product','Set_evento')

我遇到了同样的错误,设置有效的属性集ID解决了我的问题。

答案 1 :(得分:1)

基本上,外键约束错误是由于您尝试在引用的表中不存在的该列中输入值而引起的。在这种情况下 - 我会检查您是否允许在辅助表中插入主表中的值。

答案 2 :(得分:1)

我在运行导入程序时遇到了同样的问题,我发现问题是我试图更新的一些产品不存在添加此代码对我有用。

$productid = Mage::getModel('catalog/product')
            ->getIdBySku(trim($sku));
        if(!$productid){
            Mage::Log('Failed to load product with Sku:'.$sku,null,'cron.log');
            return;
        }