如何防止Magento在以编程方式更新产品时覆盖其他网站/商店的属性值

2022-08-30 21:21:36

我已经实现了自定义Magento模块,该模块通过外部服务的数据循环,并在Magento多语言,多商店网站中更新价格,重量,名称和其他一些产品属性。

我的解决方案非常简单(在Cron每天调用的模型中),如下所示:

/* THIS IS CODE SNIPPET INSIDE FOREACH LOOP */
$storeId = (string)$jobConfig->store; //cron for each store
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);

$extistingProduct = Mage::getModel('catalog/product')->loadByAttribute('sku', $sku);
$extistingProduct->setPrice($newPrice); //update price
//some code here dealing with Associated products of Configurable product probably not relevant
//...
$extistingProduct->setCanSaveConfigurableAttributes(true);
$extistingProduct->setCanSaveCustomOptions(true);

$extistingProduct->setConfigurableAttributesData($configurableAttributesData);
// This tells Magento to associate the given simple products to this configurable product..
$extistingProduct->setConfigurableProductsData($configurableProductsData);

$extistingProduct->setStoreId($storeId);

$extistingProduct->save();

我每天在cron中运行这个,每个商店都单独运行。它通常可以正常工作,仅更改每个商店的每个产品的价格,但有时会发生一些奇怪的事情(例如每2个月一次) - 除了价格之外,所有其他属性都会从商店X覆盖到当前商店。这意味着我所有受影响产品的英文产品描述都变成了德语(例如)。$storeId

我不知道这是怎么发生的,因为每次我调试它都能正常工作,只更改当前范围内的价格,这是我明确设置的,但保留了所有其他产品属性不变。它似乎从商店X加载所有产品数据,设置价格,然后存储所有这些值以存储我在通过调用保存产品之前设置的值。$extistingProduct->setStoreId($storeId)

在这种情况下,所有属性都会从同一商店被覆盖(例如,所有英语文本都变成德语,但在其他情况下,所有属性都将变成西班牙语 - 它们都来自一个随机的商店)。

有没有人知道这怎么可能发生?我做错了什么?


答案 1

是的,整个“逻辑”在Magento中非常讨厌。以下是您需要了解的内容:

当您加载产品时,您将加载当前设置为范围的内容,在您的情况下,管理员范围是默认范围。因此,您正在做的是从管理范围加载并将其保存到店面。因此,如果发生“随机”语言更改,请检查该产品的默认值,您可能会感到惊讶。

我的建议:

  1. 确保将每个产品加载到要存储的相同范围内,因此请在加载之前设置范围
  2. 请记住,每次存储产品时都会覆盖网站/全局属性
  3. 尽量避免使用内置的加载/保存方法,而是使用其他直接且仅针对所需范围写入属性的方法

我们有一个广泛的自定义产品导入/更新机制,为了使所有内容都与加载/保存一起工作,我们首先更改并保存全局值,然后为每个店面更改店面特定值加载/保存。


答案 2

我每天都做和你一样的行为,我用L. Palaiokostas提到的magmi实施了一个cron。它运行良好,我每天像那样同步200k产品。我做的是制作一个临时表,在其中收集所有外部数据,并使用magmi执行我的请求,将magento的数据与我的临时表进行比较。这给了我一个由magmi自动更新或创建的增量。

一开始我是怀疑论者,花了几个星期的时间,但它工作了一年而没有遇到麻烦!

希望这会有所帮助。


推荐