我们使用的是Magento CE 1.7.0.0,我们正在尝试为客户组实体添加新属性。我们使用以下安装脚本成功地为客户添加了自定义属性:
<?php
$installer = $this;
$installer->startSetup();
$setup = Mage::getModel('customer/entity_setup', 'core_setup');
$setup->addAttribute('customer', 'ussco_account_number', array(
'type' => 'varchar',
'input' => 'text',
'label' => 'USSCO Account Number',
'note' => 'Leave blank for default',
'global' => 1,
'visible' => 1,
'required' => 0,
'user_defined' => 0,
'default' => '',
'visible_on_front' => 0,
'source' => NULL,
));
Mage::getSingleton('eav/config')
->getAttribute('customer', 'ussco_account_number')
->setData('used_in_forms', array('adminhtml_customer'))
->save();
$installer->endSetup();
有没有人在客户群而不是客户群中做过类似的事情?
如果您查看sql安装程序/更新脚本,您会发现如下内容:
$table = $installer->getConnection()
->newTable($installer->getTable('customer/customer_group'))
->addColumn('customer_group_id', Varien_Db_Ddl_Table::TYPE_SMALLINT, null, array(
'identity' => true,
'unsigned' => true,
'nullable' => false,
'primary' => true,
), 'Customer Group Id')
->addColumn('customer_group_code', Varien_Db_Ddl_Table::TYPE_TEXT, 32, array(
'nullable' => false,
), 'Customer Group Code')
->addColumn('tax_class_id', Varien_Db_Ddl_Table::TYPE_INTEGER, null, array(
'unsigned' => true,
'nullable' => false,
'default' => '0',
), 'Tax Class Id')
->setComment('Customer Group');
正如您所看到的,这是一个简单的mysql4表,您只需要向组中添加一列。它不是EAV,所以你不需要处理那个属性!
新列将不会显示在表单或网格中!您必须通过observer手动添加,或者通过为例如文本字段添加类似内容来重写Mage_Adminhtml_Block_Customer_Group_Edit_Form
或Mage_Adminhtml_Block_Customer_Group_Grid
:
$fieldset->addField('your_column', 'text',
array(
'name' => 'Your_Column',
'label' => Mage::helper('customer')->__('Tax Class'),
'title' => Mage::helper('customer')->__('Tax Class'),
'class' => 'required-entry',
'required' => true
)
);
我同样需要在customer_group中包含一个字段。我想在这里添加我的sql脚本,将一些自定义字段添加到customer_group中
$installer = $this;
$installer->startSetup();
$installer->getConnection()->addColumn($installer->getTable('customer_group'), 'my_custom_field1', 'varchar(100)');
$installer->getConnection()->addColumn($installer->getTable('customer_group'), 'my_custom_field2', 'varchar(100)');
$installer->endSetup();
问候