报告显示其所属的所有产品及其属性,功能和类别

时间:2013-07-16 08:17:56

标签: mysql prestashop

我正在尝试构建一个报告,其中显示了所有产品及其属性,功能和类别。但我写的查询花了很多时间。我该如何改进?

[CODE]

SELECT   max(if((ps_attribute_group_lang.name like "Color"),ps_attribute_lang.name,'')) AS Color, max(if((ps_attribute_group_lang.name like "Size"),ps_attribute_lang.name,'')) AS Size, max(if((ps_feature_lang.name like "Brand"),ps_feature_value_lang.value,'')) AS Brand, max(if((ps_feature_lang.name like "Sub brand"),ps_feature_value_lang.value,'')) AS Subbrand, max(if((ps_feature_lang.name like "Occasion"),ps_feature_value_lang.value,'')) AS Occasion, max(if((ps_feature_lang.name like "Sleeves"),ps_feature_value_lang.value,'')) AS Sleeves, max(if((ps_feature_lang.name like "Cuffs"),ps_feature_value_lang.value,'')) AS Cuffs, max(if((ps_feature_lang.name like "Collar"),ps_feature_value_lang.value,'')) AS Collar, max(if((ps_feature_lang.name like "Neck"),ps_feature_value_lang.value,'')) AS Neck, max(if((ps_feature_lang.name like "Hood"),ps_feature_value_lang.value,'')) AS Hood, max(if((ps_feature_lang.name like "Shoulder"),ps_feature_value_lang.value,'')) AS Shoulder, max(if((ps_feature_lang.name like "Straps"),ps_feature_value_lang.value,'')) AS Straps, max(if((ps_feature_lang.name like "Trouser Front"),ps_feature_value_lang.value,'')) AS TrouserFront, max(if((ps_feature_lang.name like "Front Opening"),ps_feature_value_lang.value,'')) AS FrontOpening, max(if((ps_feature_lang.name like "Suit Front"),ps_feature_value_lang.value,'')) AS SuitFront, max(if((ps_feature_lang.name like "Fit"),ps_feature_value_lang.value,'')) AS Fit, max(if((ps_feature_lang.name like "Wash"),ps_feature_value_lang.value,'')) AS Wash, max(if((ps_feature_lang.name like "Length"),ps_feature_value_lang.value,'')) AS Length, max(if((ps_feature_lang.name like "Style"),ps_feature_value_lang.value,'')) AS Style, max(if((ps_feature_lang.name like "Pattern"),ps_feature_value_lang.value,'')) AS Pattern, max(if((ps_feature_lang.name like "Weatherproof"),ps_feature_value_lang.value,'')) AS Weatherproof, max(if((ps_feature_lang.name like "Fabric Type"),ps_feature_value_lang.value,'')) AS FabricType, max(if((ps_feature_lang.name like "Suit Type"),ps_feature_value_lang.value,'')) AS SuitType, max(if((ps_feature_lang.name like "Accessories"),ps_feature_value_lang.value,'')) AS Accessories, max(if((ps_feature_lang.name like "Fashion Accessories"),ps_feature_value_lang.value,'')) AS FashionAccessories, max(if((ps_feature_lang.name like "Shoe Type"),ps_feature_value_lang.value,'')) AS ShoeType, max(if((ps_feature_lang.name like "Bag Type"),ps_feature_value_lang.value,'')) AS BagType, max(if((ps_feature_lang.name like "Material"),ps_feature_value_lang.value,'')) AS Material, max(if((ps_feature_lang.name like "Ethnic Bottom Style "),ps_feature_value_lang.value,'')) AS EthnicBottomStyle,  ps_product_attribute.id_product AS productid,
`ps_product_lang`.`name` AS `productname`,
`ps_product_attribute`.`ean13`         AS `a_ean13`,
`ps_category_lang`.`name`              AS `categoryname`,
`ps_product_attribute`.`id_product_attribute`  AS `id_product_attribute`,
`t_vendorproducts`.`a_vendorid`        AS `vendorid`,
round(`ps_product`.`price`,2)  AS price   from
        (((((((`ps_product_attribute`
        join `ps_product_lang`          ON ((`ps_product_lang`.`id_product` = `ps_product_attribute`.`id_product`)))
        join `ps_product_attribute_combination` ON ((`ps_product_attribute_combination`.`id_product_attribute` = `ps_product_attribute`.`id_product_attribute`)))
        join `ps_attribute`            ON ((`ps_attribute`.`id_attribute` = `ps_product_attribute_combination`.`id_attribute`)))
        join `ps_attribute_lang`        ON ((`ps_attribute_lang`.`id_attribute` = `ps_product_attribute_combination`.`id_attribute`)))
        join `ps_attribute_group_lang`   ON (((`ps_attribute`.`id_attribute_group` = `ps_attribute_group_lang`.`id_attribute_group`))))))
        join  ps_feature_product        on ps_feature_product.id_product = ps_product_attribute.id_product
    join  ps_feature_value_lang      on ps_feature_value_lang.id_feature_value = ps_feature_product.id_feature_value
        join  ps_feature_lang           on ps_feature_product.id_feature = ps_feature_lang.id_feature
        join  ps_product               on ps_product.id_product = ps_product_attribute.id_product
    join  ps_category  cate1       on cate1.id_category = ps_product.id_category_default
    join  ps_category  cate2       on cate2.id_category = cate1.id_parent
    join  ps_category_lang        on ps_category_lang.id_category = cate1.id_category
   WHERE  ps_product_lang.id_shop = 1  GROUP BY ps_product_attribute.ean13 ORDER BY productid

[/CODE]

以下是解释的内容

"id"    "select_type"   "table" "type"  "possible_keys" "key"   "key_len"   "ref"   "rows"  "Extra"
"1" "SIMPLE"    "ps_product"    "index" "PRIMARY"   "id_category_default"   "5" \N  "5481"  "Using index; Using temporary; Using filesort"
"1" "SIMPLE"    "pa"    "ref"   "product_attribute_product,product_default" "product_attribute_product" "4" "mycode.ps_product.id_product"  "2" "Using index"
"1" "SIMPLE"    "pac"   "ref"   "id_product_attribute"  "id_product_attribute"  "4" "mycode.pa.id_product_attribute"    "1" "Using index"
"1" "SIMPLE"    "a" "eq_ref"    "PRIMARY"   "PRIMARY"   "4" "mycode.pac.id_attribute"   "1" ""
"1" "SIMPLE"    "ag"    "eq_ref"    "PRIMARY"   "PRIMARY"   "4" "mycode.a.id_attribute_group"   "1" "Using index"
"1" "SIMPLE"    "al"    "eq_ref"    "PRIMARY,id_lang"   "PRIMARY"   "8" "mycode.a.id_attribute,const"   "1" ""
"1" "SIMPLE"    "agl"   "eq_ref"    "PRIMARY"   "PRIMARY"   "8" "mycode.ag.id_attribute_group,const"    "1" ""
"1" "SIMPLE"    "ps_feature_product"    "ref"   "id_product"    "id_product"    "4" "mycode.pa.id_product"  "1" ""
"1" "SIMPLE"    "ps_feature_value_lang" "eq_ref"    "PRIMARY,ps_feature_value_lang_lang"    "PRIMARY"   "8" "mycode.ps_feature_product.id_feature_value,const"  "1" ""
"1" "SIMPLE"    "ps_feature_lang"   "eq_ref"    "PRIMARY,id_lang"   "PRIMARY"   "8" "mycode.ps_feature_product.id_feature,const"    "1" ""
"1" "SIMPLE"    "cate1" "eq_ref"    "PRIMARY"   "PRIMARY"   "4" "mycode.ps_product.id_category_default" "1" ""
"1" "SIMPLE"    "cate2" "eq_ref"    "PRIMARY"   "PRIMARY"   "4" "mycode.cate1.id_parent"    "1" "Using index"
"1" "SIMPLE"    "ps_category_lang"  "ref"   "PRIMARY,ps_category_lang_ID_CATEGORY"  "ps_category_lang_ID_CATEGORY"  "4" "mycode.cate1.id_category"  "2" "Using index"
"1" "SIMPLE"    "ps_product_lang"   "ref"   "PRIMARY"   "PRIMARY"   "4" "mycode.ps_product.id_product"  "3" "Using index"

0 个答案:

没有答案