4

我使用以下代码在我的 Magento 安装中添加了一个自定义类别属性:

<?php
//  initialize magento environment for 'default' store
    require_once 'app/Mage.php';
    Mage::app('default');

    echo "initialising";
    echo runAdd();
    echo "finishing";

function runAdd()
{
    $setup = new Mage_Eav_Model_Entity_Setup('core_setup');
    // below code will add text attribute
    $setup->addAttribute('catalog_category', 'test_field', array(
        'group'         => 'General',
        'input'         => 'text',
        'type'          => 'varchar',
        'label'         => 'a new text field',
        'backend'       => '',
        'visible'       => 1,
        'required'      => 0,
        'user_defined'  => 1,
        'global'        => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
    ));
}

实际上,我很难检索我在后端设置的值。我尝试了以下所有变体:

$_category = Mage::getModel('catalog/category')->load(1000);               
$data = $_category->getData();        
$atts= $_category->getAttributes();
var_dump($data );
var_dump($atts);

等等,但我被卡住了。

有谁知道我将如何检索这些数据?

4

2 回答 2

4

您不应该在独立脚本中更新数据库,但您必须使用升级脚本......

如果你有,你就不必手动实例化安装程序,也不会实例化一个坏的:你必须使用Mage_Catalog_Model_Resource_Setup(或Mage_Catalog_Model_Resource_Eav_Mysql4_Setup取决于你的magento版本),因为 Mage_Catalog 使用在 config.xml 中配置的自定义 Setup 类:

<resources>
    <catalog_setup>
        <setup>
            <module>Mage_Catalog</module>
            <class>Mage_Catalog_Model_Resource_Setup</class>
        </setup>
    </catalog_setup>
</resources>

我建议您在模块 config.xml 中对此进行调整,并使用安装/升级脚本正确修改您的数据库。

于 2012-10-25T12:57:29.533 回答
4

你可以写下一行可能对你有帮助

$_category = Mage::getModel('catalog/category')->load(1000)->getData('test_field');
于 2012-10-26T05:34:21.720 回答