SELECT 
  cscart_ult_product_prices.product_id, 
  MIN(
    IF(
      cscart_ult_product_prices.percentage_discount = 0, 
      cscart_ult_product_prices.price, 
      cscart_ult_product_prices.price - (
        cscart_ult_product_prices.price * cscart_ult_product_prices.percentage_discount
      )/ 100
    )
  ) AS price 
FROM 
  cscart_ult_product_prices 
WHERE 
  cscart_ult_product_prices.product_id IN (
    216, 217, 218, 219, 220, 221, 222, 223, 
    278, 279, 280, 281, 282, 283, 284, 332, 
    333, 334, 335, 336, 337, 3915, 3916, 
    3917, 3918, 3919, 3920, 3921, 3968, 
    3969, 3970, 3971, 3972, 3973, 3974, 
    4020, 4021, 4022, 4023, 4024, 4025, 
    4026, 4094, 4095, 4096, 4097, 4098, 
    4099, 4100, 4101, 4102, 4103, 4104, 
    4105, 4106, 4107, 4163, 4164, 4165, 
    4166, 4167, 4168, 4169, 4216, 4217, 
    4218, 4219, 4220, 4221, 4222, 196, 197, 
    198, 199, 200, 201, 202, 271, 272, 273, 
    274, 275, 276, 277, 325, 326, 327, 328, 
    329, 330, 415, 416, 417, 418, 3616, 3617
  ) 
  AND cscart_ult_product_prices.lower_limit = 1 
  AND cscart_ult_product_prices.company_id = 1 
  AND cscart_ult_product_prices.usergroup_id IN (0, 0, 1) 
GROUP BY 
  cscart_ult_product_prices.product_id

Query time 0.00030

JSON explain

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