SELECT 
  cscart_discussion.object_id AS product_id, 
  AVG(
    cscart_discussion_rating.rating_value
  ) AS average_rating, 
  cscart_discussion.type AS discussion_type, 
  cscart_discussion.thread_id AS discussion_thread_id 
FROM 
  cscart_discussion 
  LEFT JOIN cscart_discussion_posts ON cscart_discussion_posts.thread_id = cscart_discussion.thread_id 
  AND cscart_discussion_posts.status = "A" 
  LEFT JOIN cscart_discussion_rating ON cscart_discussion.thread_id = cscart_discussion_rating.thread_id 
  AND cscart_discussion_rating.post_id = cscart_discussion_posts.post_id 
  AND cscart_discussion_rating.rating_value != 0 
WHERE 
  cscart_discussion.object_id IN (
    89161, 89552, 91291, 90095, 90105, 90114, 
    91287, 82347, 84120, 86808, 89736, 
    89989, 89990, 89991, 89992, 86811, 
    89098, 89126, 82330, 82348, 86807, 
    86846, 89732, 83117, 83127, 83136, 
    90122, 91292, 90094, 90104, 90113, 
    89201, 91288, 83116, 83126, 83135, 
    91283, 83144, 90121, 84123, 89200, 
    83143, 84122, 82447, 91284, 91920, 
    91928, 91912
  ) 
  AND cscart_discussion.object_type = "P" 
GROUP BY 
  cscart_discussion.object_id

Query time 0.00124

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "55.46"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": false,
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_discussion",
            "access_type": "range",
            "possible_keys": [
              "object_id"
            ],
            "key": "object_id",
            "used_key_parts": [
              "object_id",
              "object_type"
            ],
            "key_length": "6",
            "rows_examined_per_scan": 48,
            "rows_produced_per_join": 48,
            "filtered": "100.00",
            "index_condition": "((`nuie_scalesta_net`.`cscart_discussion`.`object_id` in (89161,89552,91291,90095,90105,90114,91287,82347,84120,86808,89736,89989,89990,89991,89992,86811,89098,89126,82330,82348,86807,86846,89732,83117,83127,83136,90122,91292,90094,90104,90113,89201,91288,83116,83126,83135,91283,83144,90121,84123,89200,83143,84122,82447,91284,91920,91928,91912)) and (`nuie_scalesta_net`.`cscart_discussion`.`object_type` = 'P'))",
            "cost_info": {
              "read_cost": "28.81",
              "eval_cost": "4.80",
              "prefix_cost": "33.61",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "thread_id",
              "object_id",
              "object_type",
              "type"
            ]
          }
        },
        {
          "table": {
            "table_name": "cscart_discussion_posts",
            "access_type": "ref",
            "possible_keys": [
              "thread_id",
              "thread_id_2"
            ],
            "key": "thread_id",
            "used_key_parts": [
              "thread_id"
            ],
            "key_length": "3",
            "ref": [
              "nuie_scalesta_net.cscart_discussion.thread_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 48,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "12.00",
              "eval_cost": "4.80",
              "prefix_cost": "50.41",
              "data_read_per_join": "21K"
            },
            "used_columns": [
              "post_id",
              "thread_id",
              "status"
            ],
            "attached_condition": "<if>(is_not_null_compl(cscart_discussion_posts), (`nuie_scalesta_net`.`cscart_discussion_posts`.`status` = 'A'), true)"
          }
        },
        {
          "table": {
            "table_name": "cscart_discussion_rating",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "thread_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 48,
            "filtered": "100.00",
            "using_join_buffer": "hash join",
            "cost_info": {
              "read_cost": "0.25",
              "eval_cost": "4.80",
              "prefix_cost": "55.46",
              "data_read_per_join": "768"
            },
            "used_columns": [
              "rating_value",
              "post_id",
              "thread_id"
            ],
            "attached_condition": "<if>(is_not_null_compl(cscart_discussion_rating), ((`nuie_scalesta_net`.`cscart_discussion_rating`.`post_id` = `nuie_scalesta_net`.`cscart_discussion_posts`.`post_id`) and (`nuie_scalesta_net`.`cscart_discussion_rating`.`thread_id` = `nuie_scalesta_net`.`cscart_discussion`.`thread_id`) and (`nuie_scalesta_net`.`cscart_discussion_rating`.`rating_value` <> 0)), true)"
          }
        }
      ]
    }
  }
}

Result

product_id average_rating discussion_type discussion_thread_id
82330 D 90367
82347 D 90384
82348 D 90385
82447 D 90485
83116 D 91154
83117 D 91155
83126 D 91164
83127 D 91165
83135 D 91173
83136 D 91174
83143 D 91181
83144 D 91182
84120 D 92158
84122 D 92160
84123 D 92161
86807 D 94845
86808 D 94846
86811 D 94849
86846 D 94884
89098 D 97136
89126 D 97164
89161 D 97199
89200 D 97238
89201 D 97239
89552 D 97590
89732 D 97770
89736 D 97774
89989 D 98027
89990 D 98028
89991 D 98029
89992 D 98030
90094 D 98132
90095 D 98133
90104 D 98142
90105 D 98143
90113 D 98151
90114 D 98152
90121 D 98159
90122 D 98160
91283 D 99356
91284 D 99357
91287 D 99360
91288 D 99361
91291 D 99364
91292 D 99365
91912 D 99990
91920 D 99998
91928 D 100006