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 (
    94652, 94653, 94659, 94660, 94661, 94663, 
    94664, 94665, 94675, 94676, 94677, 
    94813, 94817, 94818, 94819, 95449, 
    95803, 95805, 95807, 95809, 95811, 
    97719, 97720, 97721, 97722, 97723, 
    97724, 97725, 97726, 97727, 97765, 
    97766, 97767, 97768, 97769, 97770, 
    97771, 97772, 97773, 97775, 97776, 
    97777, 97783, 97784, 97785, 97787, 
    97788, 97789
  ) 
  AND cscart_discussion.object_type = "P" 
GROUP BY 
  cscart_discussion.object_id

Query time 0.00118

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 (94652,94653,94659,94660,94661,94663,94664,94665,94675,94676,94677,94813,94817,94818,94819,95449,95803,95805,95807,95809,95811,97719,97720,97721,97722,97723,97724,97725,97726,97727,97765,97766,97767,97768,97769,97770,97771,97772,97773,97775,97776,97777,97783,97784,97785,97787,97788,97789)) 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
94652 B 102824
94653 B 102825
94659 B 102831
94660 B 102832
94661 B 102833
94663 B 102835
94664 B 102836
94665 B 102837
94675 B 102847
94676 B 102848
94677 B 102849
94813 B 102985
94817 B 102989
94818 B 102990
94819 B 102991
95449 B 103621
95803 B 103975
95805 B 103977
95807 B 103979
95809 B 103981
95811 B 103983
97719 B 105900
97720 B 105901
97721 B 105902
97722 B 105903
97723 B 105904
97724 B 105905
97725 B 105906
97726 B 105907
97727 B 105908
97765 B 105946
97766 B 105947
97767 B 105948
97768 B 105949
97769 B 105950
97770 B 105951
97771 B 105952
97772 B 105953
97773 B 105954
97775 B 105956
97776 B 105957
97777 B 105958
97783 B 105964
97784 B 105965
97785 B 105966
97787 B 105968
97788 B 105969
97789 B 105970