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 = 412 
  LEFT JOIN cscart_seo_names ON cscart_seo_names.object_id = 6364 
  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 = 6364 
  AND (
    companies.status IN ('A') 
    OR cscart_products.company_id = 0
  ) 
GROUP BY 
  cscart_products.product_id

Query time 0.04434

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": 1,
          "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": 15,
          "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": 1,
          "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 = 6364"
          },
          "buffer_type": "flat",
          "buffer_size": "185Kb",
          "join_type": "BNL",
          "attached_condition": "trigcond(ps.product_id = 6364)",
          "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
6364 10528_13 P A 469 0 992 1000.000 0 0 0 0.00 0 1655312400 1729133721 0 N N N B N N N N Y 10 N - 0 N N 0 default a:5:{s:16:"min_items_in_box";i:1;s:16:"max_items_in_box";i:1;s:10:"box_length";i:35;s:9:"box_width";i:30;s:10:"box_height";i:15;} 0 N Y vi Hộp Quà But First! Coffee, Quà Tặng Cho Người Yêu Cà Phê, Quà Tặng Cho Chàng, Quà Tặng Sinh Nhật, Ly Gốm, Phin Cà Phê, Xà Bông Thủ Công <p>Bộ quà tặng "But First, Coffee!" là món quà hoàn hảo cho những ai yêu thích cà phê. Hộp quà bao gồm ly gốm pha cà phê, phin cà phê đồng, muỗng cà phê, túi thơm cà phê, xà bông cà phê quế, lót ly gốm, và nhiều phụ kiện khác. Hộp quà được thiết kế đẹp mắt và sang trọng, thích hợp để làm quà tặng cho bạn bè, người thân hoặc đồng nghiệp.</p> <p> </p> <p style="text-align:center;"><img src="https://chus.vn/images/chus/logo/Chuschoice-ngang%202.png?1709025516494" alt="" width="254" height="54" /></p> <p style="text-align:center;"><span style="color:#000080;">Luôn nhận được đánh giá 5⭐, Cam kết đổi trả, Giao hàng nhanh chóng, Được CHUS đảm bảo chất lượng</span></p> hộp quà, quà tặng, hộp quà cà phê, set quà Hộp Quà But First! Coffee từ The Joy Box dành riêng cho những ai yêu thích cà phê với phin, túi thơm cà phê, xà bông cà phê, li gốm và thiệp tặng. , But First! Coffee Gift Box, Coffee Lover Gift Set, Coffee Accessories, Unique Coffee Gift, Ceramic Mug, Coffee-Scented Sachet, Coffee & Cinnamon Soap Hộp Quà Cà Phê But First! Coffee, The Joy Box - Chus <p><strong>1. Kích thước hộp:</strong> 25 x 30 x 10cm</p> <p><strong>2. Hộp quà bao gồm:</strong></p> <p>- Ly gốm pha cà phê</p> <p>- Phin cafe nâu đồng</p> <p>- Muỗng múc cafe kèm kẹp miệng túi</p> <p>- Túi thơm hạt cafe</p> <p>- Xà bông cafe - quế 100gr</p> <p>- Lót ly gốm 2 mặt</p> <p>- Hộp giấy carton chỉn chu, đẹp mắt</p> <p>- Tặng kèm postcard viết lời chúc &amp; túi giấy thân thiện môi trường</p> <p><strong>1. Điều kiện đổi trả</strong></p> <p>Quý khách có thể đổi trả hàng trong các trường hợp sau:</p> <p>- Hộp quà bị hư hại, móp méo nặng nề, bị rách, ướt... trong quá trình vận chuyển.</p> <p>- Sau khi mở hộp quà, món quà bị vỡ, bể, rách, không đủ số lượng hoặc mẫu mã như thông tin trên web hoặc như thỏa thuận ban đầu.</p> <p>- Một số món quà khi hết hàng, The Joy Box sẽ thay đổi màu sắc, kiểu dáng hoặc loại hàng ngang giá cho quý khách. Chúng tôi sẽ thông báo qua email/ điện thoại cho Quý khách trước khi gửi hộp quà.</p> <p>Khách hàng gửi hình ảnh tình trạng hộp quà hoặc món hàng sau khi unbox, chứng minh sự thiếu sót trên để hoàn thành việc hoàn trả/đổi trả hàng hóa.</p> <p><strong>2. Quy định về thời gian thông báo và gửi sản phẩm đổi trả:</strong></p> <p>- Thời gian thông báo đổi trả: trong vòng 7 ngày kể từ khi nhận sản phẩm đối với trường hợp sản phẩm thiếu quà tặng hoặc bể vỡ.</p> <p>- Thời gian gửi chuyển trả sản phẩm: trong vòng 14 ngày kể từ khi nhận sản phẩm.</p> <p>Địa điểm đổi trả sản phẩm: khách hàng có thể mang hàng trực tiếp đến cửa hàng The Joy Box hoặc thương hiệu sẽ hỗ trợ bạn chuyển hoàn đơn hàng.</p> <p>Hộp quà phù hợp để dành tặng bạn bè, người yêu hoặc cả người thân trong bất kì dịp nào mà bạn muốn. Với sự chuẩn bị chu đáo từ The Joy Box cùng tấm chân thành của bạn, thể hiện qua việc lựa chọn đúng quà, người nhận chắc chắn sẽ ấn tượng và nở một nụ cười trên môi.</p> <p>Mỗi món quà là một niềm vui dành cho người nhận, cũng như tình cảm và sự trân trọng của người gửi trao. Hiểu được ý nghĩa ấy, The Joy Box đã ra đời, như một cầu nối giúp bạn trao gửi lời yêu thương thông qua món an lành và giàu ý nghĩa. Thương hiệu hy vọng thông qua những sản phẩm của mình, cả người gửi lẫn người nhận đều sẽ nhận được những niềm vui trong cuộc sống, để thấy cuộc sống thật đẹp và tràn ngập những điều tích cực.</p> <p>Từng sản phẩm đều được thương hiệu tuyển chọn, mang giá trị về sức khỏe, an toàn và giúp phần nào xoa dịu tinh thần. Mỗi hộp còn có chủ đề riêng và thiết kế phù hợp cho nhiều đối tượng khác nhau. Vì vậy, bạn có thể dễ dàng lựa chọn, giúp tiết kiệm thời gian và công sức.</p> <p>Tại The Joy Box, bạn sẽ được biết thêm về các sản phẩm thiên nhiên được làm bởi các thương hiệu địa phương cùng những sản phẩm mà The Joy Box tự tay làm ra. Những món quà vừa hợp túi tiền vừa tinh tế sẽ cho bạn và người thân yêu một trải nghiệm trao-nhận thêm trọn vẹn, hoàn hảo.</p> a:4:{s:17:"rs_brand_producer";a:5:{i:0;s:46:"Thương hiệu chuyên về hộp quà tặng";i:1;s:70:"Đa dạng lựa chọn về quà tặng, phù hợp với mọi dịp";i:2;s:105:"Sản phẩm chất lượng cao, được tuyển chọn kỹ lưỡng từ các thương hiệu uy tín";i:3;s:0:"";i:4;s:0:"";}s:14:"rs_ingredients";a:5:{i:0;s:60:"Tuỳ thuộc vào các sản phẩm chứa trong hộp quà";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:44:"Sản phẩm được lựa chọn tỉ mỉ";i:1;s:36:"Sắp xếp và gói quà bằng tay";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><span style="font-weight: 400;"><img src="https://chus.vn/images/Blog/CHUS%20CHOICE/Vi2/The%20Joy%20Box_Vie.jpg?1701685340747" alt="chus choice comment" width="1008" height="221" /></span></p> <p><span style="font-weight: 400;">Hộp quà But First! Coffee là một món quà tặng ý nghĩa và tinh tế dành cho những người yêu thích cà phê.</span></p> <p><strong>Ưu điểm:</strong></p> <p><span style="font-weight: 400;">- Thiết kế bắt mắt, sang trọng, phù hợp làm quà tặng.</span></p> <p><span style="font-weight: 400;">- Sản phẩm chất lượng, có nguồn gốc xuất xứ rõ ràng.</span></p> <p><span style="font-weight: 400;">- Giá cả hợp lý.</span></p> <p><strong>Nhược điểm: </strong></p> <p><span style="font-weight: 400;">Chưa có nhiều lựa chọn về màu hộp quà.</span> </p> 1 590000.0000 412M,412M,412M,412M,412M,412M,412M,412M,412M,412M,412M,412M,412M,412M,412M 423M,416,425,426,432,434,445,473,496,497,502,504,512,515,517 63406 The Joy Box 7 hop-qua-but-first-coffee 412 D 4.98 44 14