3

アイテムを構成可能なアイテムとして 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);
}

このようなアイテムを更新できることはわかっていますが、構成可能なアイテムに追加する必要がある追加の属性は更新されません。

この情報を更新する正しい方法は何ですか?

4

2 に答える 2

2

申し訳ありませんが、コメント(?)できないので、回答欄に記入する必要があります。

  1. Magentoが製品を新しいものとして扱っているとは思いません。skuでロードしてから保存するのは通常の手順で、多くの場合はうまくいきました。

エラーメッセージが伝えようとしているのは、すでに存在する構成可能な属性の値を持つ子としてアイテムを追加しようとしているということです。たとえば、スーパー属性「size」と「size = S」のシャツを、すでに「S」が適用されている構成可能な製品に追加します。したがって、Magentoは、構成可能な製品ではなく、子を新しいものとして扱っている可能性があります。

  1. エラーメッセージのキーは「奇妙」に見えます。他の機能の1つから、見覚えがありますか?Magentoのテーブルからは認識できません。

  2. 超シンプルで超高速のマグミインポーターを使用できない理由は何ですか?;)http://sourceforge.net/projects/magmi/

よろしくサイモン

于 2013-03-09T01:27:25.560 に答える
0

私たちの経験では、在庫アイテムを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();
于 2015-08-19T09:00:45.447 に答える