SELECT 
  cscart_products.*, 
  cscart_product_descriptions.*, 
  MIN(
    IF(
      cscart_product_prices.percentage_discount = 0, 
      cscart_product_prices.price, 
      cscart_product_prices.price - (
        cscart_product_prices.price * cscart_product_prices.percentage_discount
      )/ 100
    )
  ) as price, 
  GROUP_CONCAT(
    CASE WHEN (
      cscart_products_categories.link_type = 'M'
    ) THEN CONCAT(
      cscart_products_categories.category_id, 
      'M'
    ) ELSE cscart_products_categories.category_id END 
    ORDER BY 
      cscart_categories.storefront_id IN (0, 1) DESC, 
      (
        cscart_products_categories.link_type = 'M'
      ) DESC, 
      cscart_products_categories.category_position ASC, 
      cscart_products_categories.category_id ASC
  ) as category_ids, 
  GROUP_CONCAT(
    CASE WHEN (
      cscart_products_tag_categories.link_type = 'M'
    ) THEN CONCAT(
      cscart_products_tag_categories.category_id, 
      'M'
    ) ELSE cscart_products_tag_categories.category_id END 
    ORDER BY 
      cscart_categories.storefront_id IN (0, 1) DESC, 
      (
        cscart_products_tag_categories.link_type = 'M'
      ) DESC, 
      cscart_products_tag_categories.category_position ASC, 
      cscart_products_tag_categories.category_id ASC
  ) as category_tag_ids, 
  popularity.total as popularity, 
  companies.company as company_name, 
  cscart_product_sales.amount as sales_amount, 
  cscart_seo_names.name as seo_name, 
  cscart_seo_names.path as seo_path, 
  cscart_discussion.type as discussion_type, 
  cscart_product_review_prepared_data.average_rating average_rating, 
  cscart_product_review_prepared_data.reviews_count product_reviews_count, 
  ps.sold as sold 
FROM 
  cscart_products 
  LEFT JOIN cscart_product_prices ON cscart_product_prices.product_id = cscart_products.product_id 
  AND cscart_product_prices.lower_limit = 1 
  AND cscart_product_prices.usergroup_id IN (0, 0, 1) 
  LEFT JOIN cscart_product_descriptions ON cscart_product_descriptions.product_id = cscart_products.product_id 
  AND cscart_product_descriptions.lang_code = 'vi' 
  LEFT JOIN cscart_companies as companies ON companies.company_id = cscart_products.company_id 
  INNER JOIN cscart_products_categories ON cscart_products_categories.product_id = cscart_products.product_id 
  LEFT JOIN cscart_products_tag_categories ON cscart_products_tag_categories.product_id = cscart_products.product_id 
  INNER JOIN cscart_categories ON cscart_categories.category_id = cscart_products_categories.category_id 
  AND cscart_categories.storefront_id IN (0, 1) 
  AND (
    cscart_categories.usergroup_ids = '' 
    OR FIND_IN_SET(
      0, cscart_categories.usergroup_ids
    ) 
    OR FIND_IN_SET(
      1, cscart_categories.usergroup_ids
    )
  ) 
  AND (
    cscart_products.usergroup_ids = '' 
    OR FIND_IN_SET(
      0, cscart_products.usergroup_ids
    ) 
    OR FIND_IN_SET(
      1, cscart_products.usergroup_ids
    )
  ) 
  AND cscart_categories.status IN ('A', 'H') 
  AND cscart_products.status IN ('A', 'H') 
  LEFT JOIN cscart_product_popularity as popularity ON popularity.product_id = cscart_products.product_id 
  LEFT JOIN cscart_product_sales ON cscart_product_sales.product_id = cscart_products.product_id 
  AND cscart_product_sales.category_id = 166 
  LEFT JOIN cscart_seo_names ON cscart_seo_names.object_id = 5998 
  AND cscart_seo_names.type = 'p' 
  AND cscart_seo_names.dispatch = '' 
  AND cscart_seo_names.lang_code = 'vi' 
  LEFT JOIN cscart_discussion ON cscart_discussion.object_id = cscart_products.product_id 
  AND cscart_discussion.object_type = 'P' 
  LEFT JOIN cscart_product_review_prepared_data ON cscart_product_review_prepared_data.product_id = cscart_products.product_id 
  AND cscart_product_review_prepared_data.storefront_id = 0 
  LEFT JOIN cscart_product_sold ps ON cscart_products.product_id = ps.product_id 
WHERE 
  cscart_products.product_id = 5998 
  AND (
    companies.status IN ('A') 
    OR cscart_products.company_id = 0
  ) 
GROUP BY 
  cscart_products.product_id

Query time 0.03481

JSON explain

{
  "query_block": {
    "select_id": 1,
    "nested_loop": [
      {
        "table": {
          "table_name": "cscart_products",
          "access_type": "const",
          "possible_keys": ["PRIMARY", "status"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "popularity",
          "access_type": "const",
          "possible_keys": ["PRIMARY", "total"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_product_sales",
          "access_type": "const",
          "possible_keys": ["PRIMARY", "pa"],
          "key": "PRIMARY",
          "key_length": "6",
          "used_key_parts": ["category_id", "product_id"],
          "ref": ["const", "const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_product_prices",
          "access_type": "ref",
          "possible_keys": [
            "usergroup",
            "product_id",
            "lower_limit",
            "usergroup_id"
          ],
          "key": "product_id",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,0,1))"
        }
      },
      {
        "table": {
          "table_name": "cscart_product_descriptions",
          "access_type": "const",
          "possible_keys": ["PRIMARY", "product_id"],
          "key": "PRIMARY",
          "key_length": "11",
          "used_key_parts": ["product_id", "lang_code"],
          "ref": ["const", "const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(cscart_product_descriptions.lang_code = 'vi')"
        }
      },
      {
        "table": {
          "table_name": "companies",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "4",
          "used_key_parts": ["company_id"],
          "ref": ["const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(companies.`status` = 'A')"
        }
      },
      {
        "table": {
          "table_name": "cscart_products_categories",
          "access_type": "ref",
          "possible_keys": ["PRIMARY", "pt"],
          "key": "pt",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["const"],
          "rows": 2,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_categories",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY", "c_status", "p_category_id"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["category_id"],
          "ref": ["dev_db.cscart_products_categories.category_id"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "cscart_categories.storefront_id in (0,1) and (cscart_categories.usergroup_ids = '' or find_in_set(0,cscart_categories.usergroup_ids) or find_in_set(1,cscart_categories.usergroup_ids)) and cscart_categories.`status` in ('A','H')"
        }
      },
      {
        "table": {
          "table_name": "cscart_products_tag_categories",
          "access_type": "ref",
          "possible_keys": ["pt"],
          "key": "pt",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["const"],
          "rows": 26,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_seo_names",
          "access_type": "ref",
          "possible_keys": ["PRIMARY", "dispatch"],
          "key": "PRIMARY",
          "key_length": "206",
          "used_key_parts": ["object_id", "type", "dispatch", "lang_code"],
          "ref": ["const", "const", "const", "const"],
          "rows": 2,
          "filtered": 100,
          "attached_condition": "trigcond(cscart_seo_names.`type` = 'p' and cscart_seo_names.dispatch = '' and cscart_seo_names.lang_code = 'vi')"
        }
      },
      {
        "table": {
          "table_name": "cscart_discussion",
          "access_type": "const",
          "possible_keys": ["object_id"],
          "key": "object_id",
          "key_length": "6",
          "used_key_parts": ["object_id", "object_type"],
          "ref": ["const", "const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(cscart_discussion.object_type = 'P')"
        }
      },
      {
        "table": {
          "table_name": "cscart_product_review_prepared_data",
          "access_type": "const",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "7",
          "used_key_parts": ["product_id", "storefront_id"],
          "ref": ["const", "const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "block-nl-join": {
          "table": {
            "table_name": "<derived2>",
            "access_type": "ALL",
            "rows": 12545,
            "filtered": 100,
            "attached_condition": "ps.product_id = 5998"
          },
          "buffer_type": "flat",
          "buffer_size": "256Kb",
          "join_type": "BNL",
          "attached_condition": "trigcond(ps.product_id = 5998)",
          "materialized": {
            "query_block": {
              "select_id": 2,
              "filesort": {
                "sort_key": "count(cscart_order_details.product_id) desc",
                "temporary_table": {
                  "nested_loop": [
                    {
                      "table": {
                        "table_name": "cscart_order_details",
                        "access_type": "index",
                        "key": "o_k",
                        "key_length": "6",
                        "used_key_parts": ["order_id", "product_id"],
                        "rows": 12545,
                        "filtered": 100,
                        "using_index": true
                      }
                    }
                  ]
                }
              }
            }
          }
        }
      }
    ]
  }
}

Result

product_id product_code product_type status company_id list_price amount weight length width height shipping_freight low_avail_limit timestamp updated_timestamp usergroup_ids is_edp edp_shipping unlimited_download tracking free_shipping zero_price_action is_pbp is_op is_oper is_returnable return_period is_make_to_order make_period avail_since out_of_stock_actions localization min_qty max_qty qty_step list_qty_count tax_ids age_verification age_limit options_type exceptions_type details_layout shipping_params facebook_obj_type parent_product_id buy_now_url is_stock_split_by_warehouses is_fragile lang_code product shortname short_description full_description meta_keywords meta_description search_words page_title age_warning_message promo_text specification special_note punch_line selection chus_note about_brand why_chus purchasing_notice note_from_brand is_sync_seo_url price category_ids category_tag_ids popularity company_name sales_amount seo_name seo_path discussion_type average_rating product_reviews_count sold
5998 10206_06 P A 525 0 998 1000.000 0 0 0 0.00 0 1655312400 1726252651 0 N N N B N R N N N Y 10 Y 1-2 0 N 1 0 0 0 N 0 P F default a:5:{s:16:"min_items_in_box";i:1;s:16:"max_items_in_box";i:1;s:10:"box_length";i:30;s:9:"box_width";i:30;s:10:"box_height";i:10;} 0 N Y vi Hoa Diên Vĩ, Tranh Hoa Giấy 25 x 25, Khung Tranh Trang Trí, Khung Tranh Hoa Giấy, Trang Trí Nội Thất, Tranh Thủ Công, Quà Tặng Cá Nhân Hóa <p>Hoa diên vĩ tượng trưng cho sự thủy chung và hy vọng. Hoa mang một sắc xanh tím dịu dàng và nhẹ nhàng, sẽ cho bạn một không gian thật lắng đọng, bình yên.</p> <p> </p> <p>Tranh Hoa Giấy Diên Vĩ từ May Paperflower là một sản phẩm trang trí thủ công, mang đến nét tinh tế, tao nhã cho không gian sống. Với những gian phòng có thiết kế tối giản, Tranh Hoa Giấy Diên Vĩ sẽ tạo cảm hứng nghệ thuật để chủ nhân chìm đắm hơn trong tình yêu cho hoa lá.</p> <p> </p> <h3>Để món quà thêm dấu ấn cá nhân hóa ý nghĩa, bạn có thể:</h3> <p> </p> <p>- Ghi chú tên, logo, hoặc lời nhắn bạn muốn in lên tranh vào ô "Lưu ý từ khách hàng" </p> <p> </p> <p>- Giới hạn 50 ký tự, dài không quá 3 dòng</p> , Iris, 25 x 25 Paper Flower Painting, Paper Flower Frame, Interior Decoration, Handmade Gifts, Personalized Gifts <p><strong style="background-color: #f6f3f3;">Chất liệu:</strong><span style="background-color: #f6f3f3;"> Khung gỗ thông sơn chống ẩm, hậu làm từ giấy bọc màng chống ẩm, kính trong suốt, giấy, keo dán</span></p> <p><strong>Hướng dẫn bảo quản:</strong></p> <p> </p> <p>- Dùng khăn mền khô để lau bụi bẩn bám trên khung, kiếng/mica.</p> <p> </p> <p>- Treo tranh ở nơi khô ráo, tránh tường ẩm và ánh sáng mặt trời trực tiếp.</p> <p> </p> <p>- Thường xuyên vệ sinh tranh sau mỗi 2-4 tuần để giữ cho tranh luôn sạch và mới.</p> <p>Mang màu sắc trang nhã, bức tranh phù hợp để đặt ở hầu hết không gian như phòng khách, phòng ngủ, sảnh lễ tân, hoặc một góc bàn làm việc để không khí thêm phần sinh động.</p> <p>Trong một lần đến thăm làng nghề hoa giấy Thanh Tiên xứ Huế - với hơn 300 năm lịch sử về làm hoa giấy, nhà sáng lập May Paperflower đã bị lôi cuốn bởi vẻ đẹp của những sản phẩm nghệ thuật này.</p> <p>Nhận thấy làng nghề đang gặp khó khăn trong việc duy trì và gìn giữ truyền thống do nhu cầu sử dụng hoa giấy truyền thống giảm, nhà sáng lập đã tự học hỏi nghệ thuật hoa giấy và ra đời thương hiệu hoa giấy thủ công May Paperflower vào năm 2020.</p> <p>Sản phẩm là sự kết hợp giữa sản phẩm thủ công mỹ nghệ và quy trình sản xuất hiện đại, mang đến nét đẹp mới cho sản phẩm truyền thống xứ Huế. Và từ đó, những bức tranh hoa giấy sinh động trên khung gỗ kính lần lượt ra đời.</p> <p>Tranh hoa giấy của May Paperflower giúp lưu giữ những khoảnh khắc của cuộc sống. Tiêu chí của thương hiệu chính là Design to Inspire - Tạo ra cảm hứng tốt hơn cho cảm xúc của bạn. Đồng thời, nguyên vật liệu của sản phẩm đều thân thiện với môi trường để khuyến khích lối sống xanh đến với đông đảo mọi người.</p> <p>May Paperflower hy vọng bằng sự tận tâm, tỉ mỉ từ những đôi bàn tay của những nghệ nhân xứ Huế, sản phẩm có thể mang năng lượng tích cực cho khách hàng mỗi ngày.</p> a:4:{s:17:"rs_brand_producer";a:5:{i:0;s:21:"Hoa giấy trang trí";i:1;s:86:"Theo đuổi nghệ thuật làm hoa giấy và duy trì truyền thống làng nghề";i:2;s:0:"";i:3;s:0:"";i:4;s:0:"";}s:14:"rs_ingredients";a:5:{i:0;s:26:"Gỗ, kính, thép, giấy";i:1;s:0:"";i:2;s:0:"";i:3;s:0:"";i:4;s:0:"";}s:14:"rs_manufacture";a:5:{i:0;s:11:"Thủ công";i:1;s:0:"";i:2;s:0:"";i:3;s:0:"";i:4;s:0:"";}s:17:"rs_certifications";a:5:{i:0;s:0:"";i:1;s:0:"";i:2;s:0:"";i:3;s:0:"";i:4;s:0:"";}} <p>Để món quà thêm dấu ấn cá nhân hóa ý nghĩa, bạn có thể:</p> <p> </p> <p>- Ghi chú tên, logo, hoặc lời nhắn bạn muốn in lên tranh vào ô "Lưu ý từ khách hàng" </p> <p><strong> </strong></p> <p>- Giới hạn</p> <p><strong style="color: #ff0000;">50 ký tự</strong></p> <p>, dài không quá</p> <p><strong style="color: #ff0000;">3 dòng</strong></p> 1 620000.0000 166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,166M,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409,409 416M,416M,418,418,419,419,420,420,421,421,422,422,429,429,433,433,434,434,437,437,444,444,445,445,450,450,467,467,472,472,477,477,490,490,491,491,492,492,499,499,503,503,504,504,507,507,512,512,515,515,517,517 12414 Maypaperflower 1 hoa-dien-vi-tranh-hoa-giay-25-x-25 101/166 D 5.00 15 2