sql >> Database >  >> RDS >> Mysql

Hoe alle product-ID's, sku's, productnamen en beschrijvingen in magento op te halen met alleen mysql?

De titel kan per winkelweergave verschillen. Hetzelfde geldt voor de beschrijving. Sommige winkelweergaven kunnen ook de standaardwaarden gebruiken die in de backend zijn ingesteld.

Hier is een volledige vraag over hoe u de gegevens kunt krijgen die u nodig heeft (sku, naam, beschrijving) voor alle producten voor een specifieke winkelweergave (id 1).

SELECT 
    `e`.`sku`, 
    IF(at_name.value_id > 0, at_name.value, at_name_default.value) AS `name`,
    IF(at_description.value_id > 0, at_description.value, at_description_default.value) AS `description`

FROM 
   `catalog_product_entity` AS `e` 
    INNER JOIN 
         `catalog_product_entity_varchar` AS `at_name_default` 
               ON (`at_name_default`.`entity_id` = `e`.`entity_id`) AND 
                  (`at_name_default`.`attribute_id` = (SELECT attribute_id FROM `eav_attribute` ea LEFT JOIN `eav_entity_type` et ON ea.entity_type_id = et.entity_type_id  WHERE `ea`.`attribute_code` = 'name' AND et.entity_type_code = 'catalog_product')) AND 
                  `at_name_default`.`store_id` = 0 
    LEFT JOIN 
          `catalog_product_entity_varchar` AS `at_name` 
               ON (`at_name`.`entity_id` = `e`.`entity_id`) AND 
                  (`at_name`.`attribute_id` = (SELECT attribute_id FROM `eav_attribute` ea LEFT JOIN `eav_entity_type` et ON ea.entity_type_id = et.entity_type_id  WHERE `ea`.`attribute_code` = 'name' AND et.entity_type_code = 'catalog_product')) AND 
                  (`at_name`.`store_id` = 1) 
    INNER JOIN 
         `catalog_product_entity_text` AS `at_description_default` 
               ON (`at_description_default`.`entity_id` = `e`.`entity_id`) AND 
                  (`at_description_default`.`attribute_id` = (SELECT attribute_id FROM `eav_attribute` ea LEFT JOIN `eav_entity_type` et ON ea.entity_type_id = et.entity_type_id  WHERE `ea`.`attribute_code` = 'description' AND et.entity_type_code = 'catalog_product')) AND 
                  `at_description_default`.`store_id` = 0 
    LEFT JOIN 
          `catalog_product_entity_text` AS `at_description` 
               ON (`at_description`.`entity_id` = `e`.`entity_id`) AND 
                  (`at_description`.`attribute_id` = (SELECT attribute_id FROM `eav_attribute` ea LEFT JOIN `eav_entity_type` et ON ea.entity_type_id = et.entity_type_id  WHERE `ea`.`attribute_code` = 'description' AND et.entity_type_code = 'catalog_product')) AND 
                  (`at_description`.`store_id` = 1) 

Als u het voor een andere winkelweergave wilt, vervangt u gewoon de waarde 1 met uw gewenste id op de volgende regels

(`at_name`.`store_id` = 1) 

en

(`at_description`.`store_id` = 1)

Ik weet niet waarom je dit in een sql-formaat nodig hebt. Dit is een vreemde en een grote foutbron. Je kunt het gemakkelijk krijgen via code:

$collection = Mage::getResourceModel('catalog/product_collection')
        ->addAttributeToSelect(array('sku', 'name', 'description'));
foreach ($collection as $item) {
    $sku = $item->getSku();
    $name = $item->getName();
    $description = $item->getDescription(); 
    //do something with $sku, $name & $description
}


  1. PostgreSQL:rol is niet toegestaan ​​om in te loggen

  2. Slaapstand:Deadlock gevonden bij het verkrijgen van vergrendeling

  3. Getallen opmaken in SQL Server

  4. Geautomatiseerd testen van het upgradeproces voor MySQL/MariaDB/Percona Server