我使用以下代码将选项添加到我的“下拉属性”中:

public function createAttributeOption($option){
    $arg_attribute = 'attribute_code';
    $arg_value = $option;

    $attr_model = Mage::getModel('catalog/resource_eav_attribute');
    $attr = $attr_model->loadByCode('catalog_product', $arg_attribute);
    $attr_id = $attr->getAttributeId();

    $option['attribute_id'] = $attr_id;
    $option['value']['any_option_name'][0] = $arg_value;

    $setup = new Mage_Eav_Model_Entity_Setup('core_setup');
    $setup->addAttributeOption($option);
    return '???';
}

这将选项完美地插入我的属性。问题是我需要从此功能返回插入的选项ID。如何获得最后插入选项的ID?

有帮助吗?

解决方案

尝试这个:

$lastId = $setup->getConnection()->lastInsertId();
$attr = Mage::getModel('eav/entity_attribute_option')
            ->getCollection()
            ->setStoreFilter()
            ->addFieldToFilter('tsv.value_id',array('eq'=>$lastId))
            ->getFirstItem();

$optionId = $attr->getData('option_id');
return $optionId;

其他提示

echo $order->getId();
echo $lastInsertId  = $db_write ->fetchOne('SELECT last_insert_id()');
echo $db_write ->lastInsertId(); // you may also try this.

您可以获取有关最后插入ID的所有信息点击这里

许可以下: CC-BY-SA归因
scroll top