SELECT 
  p.product_id, 
  ifnull(
    count(dp.post_id), 
    0
  ) as discussion_amount_posts 
FROM 
  cscart_discussion 
  INNER JOIN cscart_products as p ON (
    cscart_discussion.object_id = p.product_id
  ) 
  INNER JOIN cscart_discussion_posts as dp ON (
    cscart_discussion.thread_id = dp.thread_id 
    AND cscart_discussion.object_type = 'P' 
    AND cscart_discussion.company_id = 1
  ) 
WHERE 
  dp.status = 'A' 
  and p.product_id in (
    18516, 51007, 51004, 51010, 51005, 51008, 
    51012, 51013, 51006, 51011, 51015, 
    51021, 51016, 51017, 51018, 51024, 
    51019, 51014, 51022, 51045, 51422, 
    51440, 51025, 51424, 51029, 51442, 
    51429, 51060, 51436, 51433, 51430, 
    51020, 51027, 51063, 51067, 51423, 
    51435, 51031, 51062, 51028, 51441, 
    51026, 51033, 51425, 51432, 51431, 
    51030, 51032, 51035, 51434, 51041, 
    51042, 51070, 51038, 51066, 51064, 
    51069, 51037, 51040, 51052, 51059, 
    51023, 51039, 51056, 51061, 51036, 
    51050, 51065, 51009, 51034, 51426, 
    51068, 51055, 51071, 51058
  ) 
GROUP BY 
  p.product_id

Query time 0.00075

JSON explain

{
  "query_block": {
    "select_id": 1,
    "message": "no matching row in const table"
  }
}