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 = 339 
  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 = 339

Query time 0.06648

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 = 339"
          },
          "buffer_type": "flat",
          "buffer_size": "18Kb",
          "join_type": "BNL",
          "attached_condition": "trigcond(p.company_id = 339)"
        }
      },
      {
        "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
339 vi <p>"Cocovie" có thể hiểu là cái tên ghép giữa coconut - dừa và LaVie - một thương hiệu nước đóng chai đã quá quen thuộc với người dân Việt Nam. Bắt nguồn cho mối liên hệ này đơn giản chỉ là mong muốn của Hoàng Thanh Thuỷ - người sáng lập của Cocovie khi giúp đỡ một người bạn kinh doanh dầu dừa, sau khi được nhận dầu dừa từ bạn mình đựng trong vỏ chai nước LaVie.</p> <p>Là một người làm việc trong ngành kinh doanh các sản phẩm cho tóc và bản thân cũng thường xuyên đổi màu tóc, cô thực sự bất ngờ khi tự mình trải nghiệm hiệu quả tuyệt vời mà dầu dừa mang đến cho mái tóc của mình. Bên cạnh đó, đây còn là loại dầu chứa nhiều dưỡng chất tốt lành đối với sức khỏe người dùng. Cô mong muốn có thể sáng lập nên một thương hiệu cung cấp mỹ phẩm và thực phẩm làm từ dừa hiệu quả mà vẫn đảm bảo độ lành tính khi sử dụng. Lấy ý tưởng tên từ LaVie, tham vọng của cô là muốn biến Cocovie trở nên phổ biến cũng như chính thương hiệu nước đóng chai kia vậy.</p> <p>Để trao đến khách hàng những sản phẩm từ tinh dầu dừa hữu cơ nguyên chất nhất, Cocovie đã xây dựng những nhà máy ngay tại những nông trại dừa ở tỉnh Bến Tre, Việt Nam. Quy trình ép dầu dừa được diễn ra ngay sau khi thu hoạch theo mô hình không để lại bất kỳ chế phẩm thừa nào. Điều này không chỉ giúp chắt lọc những giọt dầu cô đọng và giàu dinh dưỡng nhất, mà còn bảo đảm tiêu chuẩn xanh tới người dùng và môi trường xung quanh.</p> A Cocovie Cocovie 158 Đào Duy Anh, Phường 9, quận Phú Nhuận, Thành phố Hồ Chí Minh, Việt Nam 79 768 27049 sales@cocovie.com.vn 0918343503 none Y 1643073238 5,6,4,7 0 N N N 1 0 0 0 0 0 0 N N A Y Hoa hồng người bán cocovie 4.92 1