我想以编程方式从捆绑产品中删除所有选项,我只知道产品的SKU。
我有
$bundled = Mage::getModel('catalog/product')->loadByAttribute('sku',THISISMYSKU);
$selectionCollection = $bundled->getTypeInstance(true)->getSelectionsCollection(
$bundled->getTypeInstance(true)->getOptionsIds($bundled), $bundled);
foreach($selectionCollection as $option)
{
$sku = $option->getSku();
if($sku != "")
{
$optionModel = Mage::getModel('bundle/option');
$optionModel->setId($option->option_id);
$optionModel->delete();
echo 'deleted: '.$option->getName()." optionID(".$option->option_id.")";
};
但是,如果我循环使用它,则无法正常工作,删除其他产品的选项。
试试这个
$productCollection = Mage::getModel('catalog/product')->getCollection()
->addAttributeToFilter('attribute_set_id', 4)
->addAttributeToFilter( 'sku', array( 'in' => array( 'my-sku1', 'my-sku2', 'my-sku3' ) ) )
->addAttributeToFilter('type_id','bundle')
->addFieldToFilter('status', Mage_Catalog_Model_Product_Status::STATUS_ENABLED);
foreach($productCollection as $product)
{
$bundled = Mage::getModel('catalog/product');
$bundled->load($product->getId());
$selectionCollection = $bundled->getTypeInstance(true)->getSelectionsCollection(
$bundled->getTypeInstance(true)->getOptionsIds($bundled), $bundled);
foreach($selectionCollection as $option)
{
$optionModel = Mage::getModel('bundle/option');
$optionModel->setId($option->option_id);
$optionModel->delete();
}
}
希望这对你有帮助
我最近需要清除产品中的所有选项以使用新选项进行更新。
我认为最简单的方法是:
$product->getTypeInstance()->getOptionsCollection($product)->walk('delete');
$product->save();