将自定义属性添加到sales_quote_address
题
我想向Magento中的Sales_Quote_Address
模型添加自定义属性。我现在在Google上搜索了几个小时,我找不到这样做的方法。是否可以?或者我必须在世代odicetagcode本身上设置属性,然后从那里抓住它?
谢谢
解决方案
所以,这是我最终做的事情:
$installer = $this;
$installer->startSetup();
/* @var $addressHelper Mage_Customer_Helper_Address */
$addressHelper = Mage::helper('customer/address');
$store = Mage::app()->getStore(Mage_Core_Model_App::ADMIN_STORE_ID);
/* @var $eavConfig Mage_Eav_Model_Config */
$eavConfig = Mage::getSingleton('eav/config');
// update customer address user defined attributes data
$attributes = array(
'attribute_name' => array(
'label' => 'Attribute label',
'backend_type' => 'int',
'frontend_input' => 'select',
'is_user_defined' => 0,
'is_system' => 0,
'is_visible' => 0,
'sort_order' => 140,
'is_required' => 0,
'multiline_count' => 0
),
);
foreach ($attributes as $attributeCode => $data) {
$attribute = $eavConfig->getAttribute('customer_address', $attributeCode);
$attribute->setWebsite($store->getWebsite());
$attribute->addData($data);
$usedInForms = array(
'adminhtml_customer_address',
'customer_address_edit',
'customer_register_address'
);
$attribute->setData('used_in_forms', $usedInForms);
$attribute->save();
}
$installer->run("
ALTER TABLE {$this->getTable('sales_flat_quote_address')} ADD COLUMN `column_name` TINYINT(4) DEFAULT NULL;
ALTER TABLE {$this->getTable('sales_flat_order_address')} ADD COLUMN `column_name` TINYINT(4) DEFAULT NULL;
");
$installer->endSetup();
.