php 엔터티 - 고객 엔티티에 속성 추가




인스턴스 다중 (5)

나의 현재 목표는 미리 정의 된 옵션 (백엔드에서 편집 가능한 항목이있는 모델에서로드 됨, 완료 됨)로 선택 항목으로 표시되어야하는 새로운 고객 속성 ( int 유형 포함)을 추가하는 것입니다. 나는 $installer->addAttribute() 메소드의 올바른 사용법, 특히 올바른 소스 옵션 지정에 어려움을 겪고있다. 다른 문제는 새로운 속성이 eav_entity_attribute 테이블에 저장되지 않는다는 것입니다.

Magento CE 1.5.1.0에 있습니다.


Answers

이 솔루션은 알렉스와 부추 모두 나를 위해 일했습니다. 단지 AccountController.php에 setter 함수를 추가해야합니다.

$customer->setProfession($this->getRequest()->getPost('profession')) 
                        ->save(); // Added for updating Profession

"직업"이 내 사용자 정의 속성이었습니다.


다음 스크립트를 통해 사용자 정의 모듈 mysql 설치 파일에 고객 속성을 추가하십시오.

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


$installer->addAttribute("customer", "yourattributename",  array(
    "type"     => "int",
    "backend"  => "",
    "label"    => "Bad Customer",
    "input"    => "select",
    "source"   => "eav/entity_attribute_source_boolean",
    "visible"  => true,
    "required" => false,
    "default" => "",
    "frontend" => "",
    "unique"     => false,
    "note"       => ""

    ));

        $attribute   = Mage::getSingleton("eav/config")->getAttribute("customer", "yourattributename");

고객 속성을 사용하려는 위치에 사용되는 다음 스크립트

$used_in_forms=array();

$used_in_forms[]="adminhtml_customer";
        $attribute->setData("used_in_forms", $used_in_forms)
        ->setData("is_used_for_customer_segment", true)
        ->setData("is_system", 0)
        ->setData("is_user_defined", 1)
        ->setData("is_visible", 0)
        ->setData("sort_order", 100)
        ;
        $attribute->save();

$installer->endSetup();

@ 조나단 데이 의 대답은 훌륭하고 대단히 도움이되었습니다. 그러나 setup 클래스를 Mage_Customer_Model_Entity_Setup setup 하면 Magento가 모든 작업을 수행 할 수 있습니다.

<!-- config.xml Example -->
<?xml version="1.0"?>
<config>
    <global>
        <resources>
            <acme_module_setup>
                <setup>
                    <module>Acme_Module</module>
                    <class>Mage_Customer_Model_Entity_Setup</class>
                </setup>
                <connection>
                    <use>core_setup</use>
                </connection>
            </acme_module_setup>
        </resources>
    </global>
</config>

다음은 mysql4-install-XXXphp 파일입니다.

<?php

$installer = $this;
/* @var $installer Mage_Customer_Model_Entity_Setup */

$installer->startSetup();

$installer->addAttribute(
    'customer',
    'acme_imported',
    array(
        'group'                => 'Default',
        'type'                 => 'int',
        'label'                => 'Imported into Acme',
        'input'                => 'select',
        'source'               => 'eav/entity_attribute_source_boolean',
        'global'               => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_STORE,
        'required'             => 0,
        'default'              => 0,
        'visible_on_front'     => 1,
        'used_for_price_rules' => 0,
        'adminhtml_only'       => 1,
    )
);

$installer->endSetup();

위의 adminhtml_onlyused_in_forms 논리를 모두 처리합니다. 또한 정의 group 은 그것을 정의하여 속성 그룹에 할당합니다.


이것은 text 렌더러가있는 기본 int 특성의 코드입니다.

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

$setup = new Mage_Eav_Model_Entity_Setup('core_setup');

$entityTypeId     = $setup->getEntityTypeId('customer');
$attributeSetId   = $setup->getDefaultAttributeSetId($entityTypeId);
$attributeGroupId = $setup->getDefaultAttributeGroupId($entityTypeId, $attributeSetId);

$setup->addAttribute('customer', 'your_attribute_code_here', array(
    'input'         => 'text',
    'type'          => 'int',
    'label'         => 'Some textual description',
    'visible'       => 1,
    'required'      => 0,
    'user_defined' => 1,
));

$setup->addAttributeToGroup(
 $entityTypeId,
 $attributeSetId,
 $attributeGroupId,
 'your_attribute_code_here',
 '999'  //sort_order
);

$oAttribute = Mage::getSingleton('eav/config')->getAttribute('customer', 'your_attribute_code_here');
$oAttribute->setData('used_in_forms', array('adminhtml_customer'));
$oAttribute->save();

$setup->endSetup();

속성을 추가하는 특이한 단계는 고객 속성에 고유 한 것으로 보이는 setData('used_in_forms') 입니다. 이 필드가 없으면 필드가 렌더링되지 않습니다. 어쨌든 adminhtml에서는 그렇지 않습니다. 이 배열에 대한 유효한 옵션은 customer_form_attribute 데이터베이스 테이블에서 볼 수 있습니다.

미리 정의 된 옵션을 사용하여 select 를 사용하는 경우 다음이 필요합니다.

$iAttributeId = $installer->getAttributeId($entityTypeId, 'your_attribute_code_here');
$aClasses = array('TV','DVD','Home Theatre','Air Conditioner','Stereo/Hifi','Game Console','Camcorder','VCR','Set Top Box','PVR');
$aOption = array();
$aOption['attribute_id'] = $iAttributeId;

for($iCount=0;$iCount<sizeof($aClasses);$iCount++){
    $aOption['value']['option'.$iCount][0] = $aClasses[$iCount];
}
$setup->addAttributeOption($aOption);

드롭 다운에 맞춤 소스를 사용하는 방법에 대해 알아 보겠습니다.

희망이 도움이,
JD


세션의 "환영 메시지"변수에 "Hello world"값을 저장한다고 가정 해 봅시다. 코드는 다음과 같습니다.

$inputMessage = 'Hello World';
Mage::getSingleton('core/session')->setWelcomeMessage($inputMessage);

이제 코드 / 사이트의 다른 곳에서 "환영 메시지"를 반향시키고 싶습니다.

$outputMessage = Mage::getSingleton('core/session')->getWelcomeMessage();
echo $this->__($outputMessage);




php magento custom-attributes