SELECT 
  SQL_CALC_FOUND_ROWS products.product_id, 
  descr1.product as product, 
  companies.company as company_name, 
  products.product_type, 
  products.parent_product_id, 
  cscart_product_review_prepared_data.average_rating average_rating, 
  cscart_product_review_prepared_data.reviews_count product_reviews_count 
FROM 
  cscart_products as products 
  LEFT JOIN cscart_product_descriptions as descr1 ON descr1.product_id = products.product_id 
  AND descr1.lang_code = 'vi' 
  LEFT JOIN cscart_product_prices as prices ON prices.product_id = products.product_id 
  AND prices.lower_limit = 1 
  LEFT JOIN cscart_companies AS companies ON companies.company_id = products.company_id 
  INNER JOIN cscart_products_categories as products_categories ON products_categories.product_id = products.product_id 
  INNER JOIN cscart_categories ON cscart_categories.category_id = products_categories.category_id 
  LEFT JOIN cscart_product_review_prepared_data ON cscart_product_review_prepared_data.product_id = products.product_id 
  AND cscart_product_review_prepared_data.storefront_id = 0 
WHERE 
  1 
  AND companies.status IN ('A') 
  AND (
    products.usergroup_ids = '' 
    OR FIND_IN_SET(0, products.usergroup_ids) 
    OR FIND_IN_SET(1, products.usergroup_ids)
  ) 
  AND products.status IN ('A') 
  AND prices.usergroup_id IN (0, 0, 1) 
  AND (
    (
      1 
      AND products.product_id IN (15451, 15450, 6197)
    ) 
    AND companies.status IN ('A') 
    AND prices.usergroup_id IN (0, 0, 1)
  ) 
GROUP BY 
  products.product_id 
ORDER BY 
  NULL asc

Query time 0.01243

JSON explain

{
  "query_block": {
    "select_id": 1,
    "nested_loop": [
      {
        "table": {
          "table_name": "products",
          "access_type": "range",
          "possible_keys": ["PRIMARY", "status"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "rows": 3,
          "filtered": 51.89157104,
          "index_condition": "products.product_id in (15451,15450,6197)",
          "attached_condition": "(products.usergroup_ids = '' or find_in_set(0,products.usergroup_ids) or find_in_set(1,products.usergroup_ids)) and products.`status` = 'A'"
        }
      },
      {
        "table": {
          "table_name": "descr1",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY", "product_id"],
          "key": "PRIMARY",
          "key_length": "11",
          "used_key_parts": ["product_id", "lang_code"],
          "ref": ["dev_db.products.product_id", "const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(descr1.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": ["dev_db.products.company_id"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "companies.`status` = 'A'"
        }
      },
      {
        "table": {
          "table_name": "cscart_product_review_prepared_data",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "7",
          "used_key_parts": ["product_id", "storefront_id"],
          "ref": ["dev_db.products.product_id", "const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "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": ["dev_db.products.product_id"],
          "rows": 1,
          "filtered": 99.9960556,
          "attached_condition": "prices.lower_limit = 1 and prices.usergroup_id in (0,0,1) and prices.usergroup_id in (0,0,1)"
        }
      },
      {
        "table": {
          "table_name": "products_categories",
          "access_type": "ref",
          "possible_keys": ["PRIMARY", "pt"],
          "key": "pt",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["dev_db.products.product_id"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_categories",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY", "p_category_id"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["category_id"],
          "ref": ["dev_db.products_categories.category_id"],
          "rows": 1,
          "filtered": 100,
          "using_index": true
        }
      }
    ]
  }
}

Result

product_id product company_name product_type parent_product_id average_rating product_reviews_count
6197 Xà Phòng Thảo Mộc Dưỡng Da, Giúp Da Thải Độc, Nuôi Dưỡng Làn Da Khoẻ Mạnh, Kháng Khuẩn Cho Da, Thàng Phần Thiên Nhiên, Hương Thơm Dịu Nhẹxà phòng thảo mộc dưỡng da, giúp da thải độc, nuôi dưỡng làn da khoẻ mạnh, kháng khuẩn cho da, thàng phần thiên nhiên, Lecteur De Craft P 0 5.00 2
15450 Xà Phòng Thảo Mộc Dưỡng Da, Giúp Da Thải Độc, Nuôi Dưỡng Làn Da Khoẻ Mạnh, Kháng Khuẩn Cho Da, Thàng Phần Thiên Nhiên, Hương Thơm Dịu Nhẹxà phòng thảo mộc dưỡng da, giúp da thải độc, nuôi dưỡng làn da khoẻ mạnh, kháng khuẩn cho da, thàng phần thiên nhiên, Lecteur De Craft V 6197 5.00 2
15451 Xà Phòng Thảo Mộc Dưỡng Da, Giúp Da Thải Độc, Nuôi Dưỡng Làn Da Khoẻ Mạnh, Kháng Khuẩn Cho Da, Thàng Phần Thiên Nhiên, Hương Thơm Dịu Nhẹxà phòng thảo mộc dưỡng da, giúp da thải độc, nuôi dưỡng làn da khoẻ mạnh, kháng khuẩn cho da, thàng phần thiên nhiên, Lecteur De Craft V 6197 5.00 2