php - 保存现有可配置项时出现完整性约束冲突错误

标签 php magento magento-1.7

我正在将项目作为可配置项目导入 Magento。当我创建库存项目时,一切正常,但是当更新项目时,它会产生此错误:

SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '315-315' for key 'UNQ_TEST1_CATALOG_PRODUCT_SUPER_LINK_PRODUCT_ID_PARENT_ID'

我使用的代码块是这样的:

//Try and open for edit.
$product = Mage::getModel('catalog/product')->loadByAttribute('sku', $stockCode);            

//Fetch data from XML and update stock item.
$productData = $this->getProductDataArray($stockItem, $stockCategoryList);
$this->saveStockItem($stockItem, $product, 'configurable', $setId, $productData);


//Reopen the stock item to get any changes.
$product = Mage::getModel('catalog/product')->loadByAttribute('sku', $stockCode);

//Build a list of existing attributes for this config product so we can check existing attributes etc.
$existingConfigAttributes = $this->getExistingConfigurableAttributes($product);
$configurableProductsData = $this->getConfigurableProductData($product, $existingConfigAttributes);
$configurableAttributesData = $this->getConfigurableAttributeProductData($product, $existingConfigAttributes);

//Set the configurable attribute information
if ($configurableProductsData != null)
    $product->setConfigurableProductsData($configurableProductsData);
if ($configurableAttributesData != null)
    $product->setConfigurableAttributesData($configurableAttributesData);
$product->setCanSaveConfigurableAttributes(1);
$product->save(); 

第一次一切正常,我的可配置项目按预期工作。但是,如果我再次运行它,它会落在 $product->save(); 上。我假设它试图将其视为一个新项目而不是现有项目,因此试图在不应该插入的地方插入。

$this->saveStockItem() 包含:

$stockCode = (string)$stockItem->STOCK_CODE;
if ($product)
{
    $productId = $product->getId();
}

$mc = new Mage_Catalog_Model_Product_Api();
if ($this->validId($productId))
{
    $mc->update($productId, $productData);
    return $productId;
}
else
{
    return $mc->create($type, $setId, $stockCode, $productData);
}

我知道我可以像这样更新项目,但这不会更新我需要添加到可配置项目的额外属性。

更新此信息的正确方法是什么?

最佳答案

抱歉,无法评论(?),所以我必须填写答案栏。

  1. 我不认为 Magento 试图将产品视为新产品;按 sku 加载然后保存是一个正常过程,在很多情况下对我有用。

错误消息试图说明的是,我猜,您正在尝试添加一个项目作为子项目,该项目在任何已存在的可配置属性中具有值;例如,将带有 super 属性“size”和“size=S”的衬衫添加到已经应用了“S”的可配置产品。所以,也许 Magento 将 child 视为新产品 - 而不是可配置产品。

  1. 错误消息中的 key 看起来“很奇怪”。从您的其他职能来看,您是否觉得它很熟悉?我无法从任何 magento 表格中识别出它。

  2. 是什么让您无法使用 super 简单、快如闪电的 magmi 导入器? ;) http://sourceforge.net/projects/magmi/

问候 西蒙

关于php - 保存现有可配置项时出现完整性约束冲突错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15158241/

相关文章:

php - Magento:产品从购物车移至愿望 list

php - Magento 获取某个类别的所有产品按 'Position' 字段排序

Magento - 忘记密码链接生成使用了不正确的商店 View

php - 如何防止 php "exec"参数中的恶意注入(inject)(webhook -> bash 脚本)

php - Swiftmailer 捕获到异常 : Expected response code 250 but got code "",,消息为 ""

magento - 如何在 Magento 中获取完整的产品图片网址

Magento Api错误 fatal error : Uncaught SoapFault exception: [4] Resource path is not callable

php - 需要帮助构建查询 laravel 5.2

php - 如何检查用户是否在 Prestashop 的结帐页面

php - Magento 1.1.2 在数据库中哪里存储订单?