Как получить определенное значение атрибута продукта, если я знаю идентификатор продукта без загрузки всего продукта?
Атрибут продукта Magento Get Value
Ответ 1
Mage::getResourceModel('catalog/product')->getAttributeRawValue($productId, 'attribute_code', $storeId);
Ответ 2
Способ, которым я знаю:
$product->getResource()->getAttribute($attribute_code)
->getFrontend()->getValue($product)
Ответ 3
вы можете использовать
<?php echo $product->getAttributeText('attr_id') ?>
Ответ 4
Кажется невозможным получить ценность без загрузки модели продукта. Если вы посмотрите на файл app/code/core/Mage/Eav/Model/Entity/Attribute/Frontend/Abstract.php, вы увидите метод
public function getValue(Varien_Object $object)
{
$value = $object->getData($this->getAttribute()->getAttributeCode());
if (in_array($this->getConfigField('input'), array('select','boolean'))) {
$valueOption = $this->getOption($value);
if (!$valueOption) {
$opt = new Mage_Eav_Model_Entity_Attribute_Source_Boolean();
if ($options = $opt->getAllOptions()) {
foreach ($options as $option) {
if ($option['value'] == $value) {
$valueOption = $option['label'];
}
}
}
}
$value = $valueOption;
}
elseif ($this->getConfigField('input')=='multiselect') {
$value = $this->getOption($value);
if (is_array($value)) {
$value = implode(', ', $value);
}
}
return $value;
}
Как вы можете видеть, для этого метода требуется загруженный объект для получения данных из него (3-я строка).
Ответ 5
Пожалуйста, см. Daniel Kocherga answer, поскольку он будет работать для вас в большинстве случаев.
В дополнение к этому методу, чтобы получить значение атрибута, вы иногда можете получить метку select
или multiselect
. В этом случае я создал этот метод, который я храню в вспомогательном классе:
/**
* @param int $entityId
* @param int|string|array $attribute atrribute ids or codes
* @param null|int|Mage_Core_Model_Store $store
*
* @return bool|null|string
* @throws Mage_Core_Exception
*/
public function getAttributeRawLabel($entityId, $attribute, $store=null) {
if (!$store) {
$store = Mage::app()->getStore();
}
$value = (string)Mage::getResourceModel('catalog/product')->getAttributeRawValue($entityId, $attribute, $store);
if (!empty($value)) {
return Mage::getModel('catalog/product')->getResource()->getAttribute($attribute)->getSource()->getOptionText($value);
}
return null;
}
Ответ 6
Сначала мы должны убедиться, что нужный атрибут загружен, а затем вывести его. Используйте это:
$product = Mage::getModel('catalog/product')->load('<product_id>', array('<attribute_code>'));
$attributeValue = $product->getResource()->getAttribute('<attribute_code>')->getFrontend()->getValue($product);
Ответ 7
Попробуйте это
$attribute = $_product->getResource()->getAttribute('custom_attribute_code');
if ($attribute)
{
echo $attribute_value = $attribute ->getFrontend()->getValue($_product);
}
Ответ 8
Вам не нужно загружать весь продукт. Коллекции Magentos очень мощные и умные.
$collection = Mage::getModel('catalog/product')->getCollection();
$collection->addAttributeToFilter('entity_id', $product->getId());
$collection->addAttributeToSelect('manufacturer');
$product = $collection->getFirstItem();
$manufacturer = $product->getAttributeText('manufacturer');
В тот момент, когда вы вызываете getFirstItem(), запрос будет выполнен, а результат продукта будет минимальным:
[status] => 1
[entity_id] => 38901
[type_id] => configurable
[attribute_set_id] => 9
[manufacturer] => 492
[manufacturer_value] => JETTE
[is_salable] => 1
[stock_item (Varien_Object)] => Array
(
[is_in_stock] => 1
)
Ответ 9
Этот работает -
echo $_product->getData('ATTRIBUTE_NAME_HERE');
Ответ 10
Вы можете написать метод, который будет делать это напрямую через sql. Я полагаю.
Будет выглядеть примерно так:
Переменные
$store_id = 1;
$product_id = 1234;
$attribute_code = 'manufacturer';
Query:
SELECT value FROM eav_attribute_option_value WHERE option_id IN (
SELECT option_id FROM eav_attribute_option WHERE FIND_IN_SET(
option_id,
(SELECT value FROM catalog_product_entity_varchar WHERE
entity_id = '$product_id' AND
attribute_id = (SELECT attribute_id FROM eav_attribute WHERE
attribute_code='$attribute_code')
)
) > 0) AND
store_id='$store_id';
Вам нужно будет получить значение из правильной таблицы на основе атрибута backend_type (поле в eav_attribute), хотя для этого требуется как минимум 1 дополнительный запрос.
Ответ 11
Если у вас есть атрибут text/textarea с именем my_attr, вы можете получить его:
product->getMyAttr();