Po pierwsze, nie jest to prawidłowy plik config.xml. Klasa konfiguracji jest skonfigurowana w następujący sposób:
<config>
...
<global>
...
<resources>
...
<your_module_setup>
<setup>
<module>Your_Module</module>
<class>Mage_Eav_Model_Entity_Setup</class>
</setup>
</your_module_setup>
...
</resources>
...
</global>
...
</config>
zamiast Mage_Eav_Model_Entity_Setup możesz również użyć własnej klasy konfiguracji, ale powinna ona dziedziczyć Mage_Eav_Model_Entity_Setup, więc możesz użyć addAttribute zamiast ręcznie fałszować zapytania SQL.
Wtedy twój skrypt instalacyjny powinien wyglądać podobnie do tego:
$installer = $this;
$installer->startSetup();
/*
* adds product unit attribute to product
*/
$installer->addAttribute(Mage_Catalog_Model_Product::ENTITY, 'productunit_id', array(
'label' => Mage::helper('productunits')->__('Quantity Unit'),
'type' => 'int',
'input' => 'select',
'source' => SGH_ProductUnits_Model_Entity_Attribute_Source_Units::MODEL,
'backend' => SGH_ProductUnits_Model_Entity_Attribute_Backend_Units::MODEL,
'required' => 1,
'global' => 1,
'note' => Mage::helper('productunits')->__('This will be displayed next to any Qty value.')
));
$installer->endSetup();
To mój kod dodaje atrybut jednostki ilości, nie dajcie się zmylić przez użycie stałych klas, to są tylko odpowiadające aliasy klas.