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 (
    10447, 12691, 12692, 12693, 12694, 12695, 
    12696, 12697, 12698, 12699, 10206, 
    10209, 10216, 10203, 10204, 10205, 
    10207, 10208, 10210, 10211
  ) 
  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.00073

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 (10447,12691,12692,12693,12694,12695,12696,12697,12698,12699,10206,10209,10216,10203,10204,10205,10207,10208,10210,10211)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
10203 1894.30000000
10204 1894.30000000
10205 1894.30000000
10206 1894.30000000
10207 1894.30000000
10208 1894.30000000
10209 1894.30000000
10210 1894.30000000
10211 1894.30000000
10216 1894.30000000
10447 1894.30000000
12691 1894.30000000
12692 1894.30000000
12693 1894.30000000
12694 1894.30000000
12695 1894.30000000
12696 1894.30000000
12697 1894.30000000
12698 1894.30000000
12699 1894.30000000