【问题标题】:Integrity constraint violation error when saving an existing Configurable Item保存现有可配置项时出现完整性约束违规错误
【发布时间】:2013-03-01 12:51:09
【问题描述】:

我将项目作为可配置项目导入 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);
}

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

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

【问题讨论】:

  • 您是否直接在数据库中进行了一些更改,当我直接修改某些产品属性时,我也遇到了同样的问题

标签: php magento magento-1.7


【解决方案1】:

对不起,不能评论(?),所以我必须填写答案字段。

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

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

  1. 错误消息中的键看起来很“奇怪”。从您的其他功能之一看,您觉得它很熟悉吗?我从任何 magento 表中都认不出它。

  2. 是什么让您无法使用超级简单且速度极快的 magmi 导入器? ;) http://sourceforge.net/projects/magmi/

问候 西蒙

【讨论】:

    【解决方案2】:

    根据我们的经验,我们必须使用 product_idstock_id 初始化库存项目,否则当我尝试保存产品时会得到 Integrity constraint violation

    $stockItem = Mage::getModel('cataloginventory/stock_item')->loadByProduct($productId);
    if($stockItem && !$stockItem->getProductId()) { // CHECK STOCK ITEM IS INITIALISED
        $stockItem->setData('product_id', $productId);
        $stockItem->setData('stock_id', 1);
    }
    
    $stockItem->setData('use_config_manage_stock', 0);
    $stockItem->setData('manage_stock', 1);
    $stockItem->setData('is_in_stock', 1);
    $stockItem->setData('qty', 5);
    $stockItem->save();
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-07-22
      • 2012-11-23
      • 2012-10-10
      • 2020-04-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多