SELECT 
  cscart_product_prices.product_id, 
  MIN(
    IF(
      cscart_product_prices.percentage_discount = 0, 
      cscart_product_prices.price, 
      cscart_product_prices.price - (
        cscart_product_prices.price * cscart_product_prices.percentage_discount
      )/ 100
    )
  ) AS price 
FROM 
  cscart_product_prices 
WHERE 
  cscart_product_prices.product_id IN (
    802, 207, 205, 206, 201, 204, 203, 202, 
    597, 589, 1750, 713, 466, 535, 423, 534, 
    501, 1493, 531, 465, 588, 644, 640, 646
  ) 
  AND cscart_product_prices.lower_limit = 1 
  AND cscart_product_prices.usergroup_id IN (0, 1) 
GROUP BY 
  cscart_product_prices.product_id

Query time 0.00123

JSON explain

{
  "query_block": {
    "select_id": 1,
    "table": {
      "table_name": "cscart_product_prices",
      "access_type": "range",
      "possible_keys": ["usergroup", "product_id", "lower_limit", "usergroup_id"],
      "key": "product_id",
      "key_length": "3",
      "used_key_parts": ["product_id"],
      "rows": 24,
      "filtered": 4.897957802,
      "index_condition": "cscart_product_prices.product_id in (802,207,205,206,201,204,203,202,597,589,1750,713,466,535,423,534,501,1493,531,465,588,644,640,646)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
201 0.00000000
202 0.00000000
203 0.00000000
204 0.00000000
205 0.00000000
206 125000.00000000
207 0.00000000
423 250000.00000000
465 260000.00000000
466 265000.00000000
501 260000.00000000
531 265000.00000000
534 0.00000000
535 0.00000000
588 260000.00000000
589 0.00000000
597 0.00000000
640 0.00000000
644 0.00000000
646 0.00000000
713 250000.00000000
802 0.00000000
1493 260000.00000000
1750 260000.00000000