ensembles d'attributs avec des attributs spécifiques
-
16-10-2019 - |
Question
Comment puis-je obtenir une collection avec les ensembles d'attributs qui contiennent un attribut
Je veux être en mesure do à cette collection à partir d'une seule promenade (sur simple sélection), pour éviter de charger chaque jeu d'attributs et de vérifier les attributs à l'intérieur.
Je sais que ce coutures comme des choses standard, mais je suis un peu lent ces jours-ci.
La solution
$attributeId = 96;
$collection = Mage::getModel('eav/entity_attribute_set')
->getCollection()
->addFieldToFilter('eav_entity_attribute.attribute_id', $attributeId)
->addFieldToFilter('eav_entity_type.entity_type_code', Mage_Catalog_Model_Product::ENTITY)
->join(array('eav_entity_type'=> 'eav/entity_type'), 'eav_entity_type.entity_type_id=main_table.entity_type_id','entity_type_code')
->join(array('eav_entity_attribute'=> 'eav/entity_attribute'), 'eav_entity_attribute.attribute_set_id=main_table.attribute_set_id', 'attribute_id');
Autres conseils
J'ai trouvé ce juste avant @mageUz a écrit la réponse parfaite. Il est rapide si vous avez besoin que les ids de jeu d'attributs. Peut-être que quelqu'un d'autre a besoin il.
$attributeId = 123;
$setInfo = Mage::getResourceModel('eav/entity_attribute_set')
->getSetInfo(array($attributeId));
$attributeSetIds = array_keys($setInfo[$attributeId]);
Je ne sais pas comment le faire avec des objets Magento, mais une requête directe fonctionnerait tout aussi bien je suppose que
SELECT `eav_entity_attribute`.`attribute_set_id`
FROM `eav_attribute` , `eav_entity_attribute`
WHERE `eav_attribute`.`attribute_code` = 'cost'
AND `eav_attribute`.`attribute_id` = `eav_entity_attribute`.`attribute_id`
Vous pouvez utiliser le code ci-dessous pour obtenir tous les attributs de jeu d'attribut particulier.
$data = Mage::getResourceModel('catalog/product_attribute_collection')
->setAttributeSetFilter(9) // Add attribute set ID
->load();