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 (
    10075, 10135, 9952, 10074, 10573, 10577, 
    10651, 10642, 12529, 12515, 12525, 
    12532, 12523, 10198, 10557, 10202, 
    10556, 10101, 10558, 10142
  ) 
  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.00064

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": 20,
      "filtered": 99.23484039,
      "index_condition": "cscart_product_prices.product_id in (10075,10135,9952,10074,10573,10577,10651,10642,12529,12515,12525,12532,12523,10198,10557,10202,10556,10101,10558,10142)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
9952 2041.00000000
10074 2369.00000000
10075 2369.00000000
10101 2405.00000000
10135 2041.00000000
10142 2121.00000000
10198 2405.00000000
10202 2405.00000000
10556 2658.00000000
10557 2658.00000000
10558 2658.00000000
10573 2369.00000000
10577 2041.00000000
10642 2369.00000000
10651 2041.00000000
12515 0.00000000
12523 0.00000000
12525 0.00000000
12529 0.00000000
12532 0.00000000