Magento:以编程方式从属性集中删除属性

时间:2012-07-09 14:57:22

标签: magento attributes installation

我需要一个函数或一些代码来从分配给它的集合中删除一个属性。我知道这个函数,分配一个属性:

$setup->addAttributeToSet($entityTypeId, $setId, $groupId, $attributeId, $sortOrder=null)

或删除属性:

$setup->removeAttribute($entityTypeId, $code)

但不应删除该属性。必须再次无法在AttributeSet中显示属性'Default'(组'General')。

我找不到像以下那样的功能:

removeAttributeFromAttributeSet()

或某事。像那样

4 个答案:

答案 0 :(得分:9)

您可以在设置脚本中尝试此代码

<?php
/** @var $this Mage_Eav_Model_Entity_Setup */
$this->startSetup();

$this->deleteTableRow(
    'eav/entity_attribute', 
    'attribute_id', 
    $this->getAttributeId('catalog_product', 'attribute_code_here'), 
    'attribute_set_id', 
    $this->getAttributeSetId('catalog_product', 'Default')
);

$this->endSetup();

答案 1 :(得分:0)

现在这是我使用的完整代码,并且有效:

$installer = $this;
$installer->startSetup();

$attributeType = 'catalog_product';

$attribute_set_name = 'Default';

$attributeCode='my_attribute';

$setId = $installer->getAttributeSetId('catalog_product', $attribute_set_name);

$attributeId=$installer->getAttributeId($attributeType, $attributeCode);

$installer->deleteTableRow('eav/entity_attribute', 'attribute_id', $attributeId, 'attribute_set_id', $setId);

$installer->endSetup();

答案 2 :(得分:0)

//它将永久删除您的属性。

$Attributes = array('accessories_size','accessories_type','apparel_type','author_artist','bag_luggage_type','bedding_pattern','bed_bath_type','books_music_type','camera_megapixels',
'camera_type','coater','color','colors','cost','decor_type','ebizmarts_mark_visited','electronic_type','featured','fit','format','frame_style','gender','gendered','genre','homeware_style',
'home_decor_type','impressions','is_sold','jewelry_type','length','lens_type','luggage_size','luggage_style','luggage_travel_style','make','manufacturer','material','model','necklace_length',
'occasion','perfector','sample_item_1','sheet_size','shoe_size','shoe_type','size','sleeve_length','style');

$entityType = 'catalog_product';

foreach($Attributes as $index => $attrCode){

        $attributeId = Mage::getResourceModel('eav/entity_attribute')->getIdByCode($entityType,$attrCode);   // it return false when attribute not exist.

        if($attributeId){
            Mage::getModel('catalog/product_attribute_api')->remove($attributeId);          
        }
}

答案 3 :(得分:0)

下面将从attributeset

中删除属性
<?php 
$installer = $this;
$installer->startSetup();
$setup = new Mage_Eav_Model_Entity_Setup('core_setup');
$entityTypeId = $setup->getEntityTypeId('catalog_product');
$attributeId = $setup->getAttributeId('catalog_product', 'feature'); //feature is attribute code
$attributeSetId = $setup->getAttributeSetId($entityTypeId, 'Default');
$installer->deleteTableRow('eav/entity_attribute', 'attribute_id', $attributeId, 'attribute_set_id', $attributeSetId);                    
$installer->endSetup();
?>