SELECT 
  company_descriptions.*, 
  companies.*, 
  cscart_vendor_plan_descriptions.plan, 
  cscart_seo_names.name as seo_name, 
  cscart_seo_names.path as seo_path, 
  CAST(
    AVG(`prd`.`average_rating`) AS DECIMAL(10, 2)
  ) AS average_rating, 
  prd.reviews_count product_reviews_count 
FROM 
  cscart_companies AS companies 
  LEFT JOIN cscart_company_descriptions AS company_descriptions ON company_descriptions.company_id = companies.company_id 
  AND company_descriptions.lang_code = 'vi' 
  LEFT JOIN cscart_vendor_plan_descriptions ON companies.plan_id = cscart_vendor_plan_descriptions.plan_id 
  AND cscart_vendor_plan_descriptions.lang_code = 'vi' 
  LEFT JOIN cscart_seo_names ON cscart_seo_names.object_id = 698 
  AND cscart_seo_names.type = 'm' 
  AND cscart_seo_names.dispatch = '' 
  AND cscart_seo_names.lang_code = 'vi' 
  LEFT JOIN cscart_products p ON p.company_id = companies.company_id 
  LEFT JOIN cscart_product_review_prepared_data prd ON p.product_id = prd.product_id 
WHERE 
  companies.company_id = 698

Query time 0.06429

JSON explain

{
  "query_block": {
    "select_id": 1,
    "const_condition": "1",
    "nested_loop": [
      {
        "table": {
          "table_name": "companies",
          "access_type": "const",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "4",
          "used_key_parts": ["company_id"],
          "ref": ["const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "company_descriptions",
          "access_type": "const",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "10",
          "used_key_parts": ["company_id", "lang_code"],
          "ref": ["const", "const"],
          "rows": 1,
          "filtered": 100
        }
      },
      {
        "table": {
          "table_name": "cscart_vendor_plan_descriptions",
          "access_type": "const",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "10",
          "used_key_parts": ["plan_id", "lang_code"],
          "ref": ["const", "const"],
          "rows": 1,
          "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` = 'm' and cscart_seo_names.dispatch = '' and cscart_seo_names.lang_code = 'vi')"
        }
      },
      {
        "block-nl-join": {
          "table": {
            "table_name": "p",
            "access_type": "ALL",
            "rows": 25270,
            "filtered": 100,
            "attached_condition": "p.company_id = 698"
          },
          "buffer_type": "flat",
          "buffer_size": "18Kb",
          "join_type": "BNL",
          "attached_condition": "trigcond(p.company_id = 698)"
        }
      },
      {
        "table": {
          "table_name": "prd",
          "access_type": "ref",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "ref": ["dev_db.p.product_id"],
          "rows": 562,
          "filtered": 100,
          "attached_condition": "trigcond(trigcond(p.product_id is not null))"
        }
      }
    ]
  }
}

Result

company_id lang_code company_description terms status company company_search address city city_id district_id ward_id state country zipcode email phone url storefront secure_storefront entry_page redirect_customer countries_list timestamp shippings logos request_user_id request_account_name request_account_data tax_number pre_moderation pre_moderation_edit pre_moderation_edit_vendors plan_id suspend_date grace_period_start last_time_suspended last_debt_notification_time paypal_commerce_platform_account_id stripe_connect_account_id stripe_connect_account_type sended_email_notify ghn_shop_id verify show_homepage messenger messenger_flag plan seo_name seo_path average_rating product_reviews_count
698 en <p><span style="font-weight: 400;">Sau mỗi chuyến du lịch, hẳn ai cũng đều mong muốn có thể lưu trữ lại những giây phút, kỷ niệm tuyệt vời bằng hình ảnh hay quà lưu niệm. Đó cũng chính là điều mà 90’s DIY, một nhóm bạn trẻ giàu hoài bão, yêu mến du lịch và thủ công luôn nghĩ đến. Cùng nhau, họ tạo nên 90’s DIY - nơi mang đến những mô hình lắp ráp thu nhỏ, để bạn tạo ra một thế giới thu nhỏ làm ra từ chính đôi tay của mình! </span></p> <p><span style="font-weight: 400;">Các mô hình lắp ráp của 90’s DIY là phiên bản thu nho của các địa điểm nổi tiếng như Huế, Hội An và Đà Lạt. Bằng đôi bàn tay của mình, bạn có thể dựng nên từng mảnh tường, cánh cửa từ các mảnh ghép bé nhỏ nhưng tinh xảo, rồi tạo nên cả khối kiến trúc đẹp mắt. Bên cạnh các địa điểm nổi tiếng, tại 90’s DIY còn có những mẫu nam châm gắn tủ kích cỡ 1:35, được lấy cảm hứng từ sự vật, sự việc mà thuở nhỏ ai cũng thân thuộc. Tất nhiên, những mẫu nam châm cũng vô cùng chi tiết và tỉ mỉ như mô hình lắp ráp DIY, giúp mang đến cho bạn những cảm giác chân thật nhất.</span></p> <p><span style="font-weight: 400;">Với mỗi sản phẩm tạo ra, thương hiệu hy vọng có thể cùng bạn lưu giữ kỷ niệm đẹp đẽ sau mỗi chuyến đi, hay những ký ức mang ý nghĩa tinh thần sâu sắc. Vậy, bạn đã sẵn sàng cùng The 90’s DIY và Chus tạo ra kho lưu trữ của riêng mình với những tác phẩm đầy tinh xảo chưa?</span></p> A The 90's DIY The 90's DIY 152/26 Vĩnh Viễn Phường 9 Quận 10 79 771 27181 nick.nguyen@the90sdiy.com 0939797935 none Y 1680586510 6,4,7 0 a:4:{s:14:"company_fields";a:1:{i:37;s:19:"Nguyen Ba Minh Nhut";}s:15:"admin_firstname";s:19:"Nguyen Ba Minh Nhut";s:14:"admin_lastname";s:0:"";s:6:"fields";a:0:{}} N N N 1 0 0 0 0 0 0 Y N A Y Hoa hồng người bán the-90s-diy-vi 4.90 9