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 (
    10221, 10222, 10144, 10145, 10146, 10147, 
    10148, 10149, 10150, 10151, 10152, 
    12969, 10103, 10104, 10105, 10106, 
    12944, 10043, 10044, 10045
  ) 
  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.00093

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 (10221,10222,10144,10145,10146,10147,10148,10149,10150,10151,10152,12969,10103,10104,10105,10106,12944,10043,10044,10045)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
10043 1929.60000000
10044 1929.60000000
10045 1672.00000000
10103 4702.31000000
10104 4702.31000000
10105 4702.31000000
10106 4702.31000000
10144 1606.00000000
10145 1606.00000000
10146 1606.00000000
10147 1606.00000000
10148 1606.00000000
10149 1606.00000000
10150 1606.00000000
10151 1606.00000000
10152 1606.00000000
10221 1894.30000000
10222 1894.30000000
12944 1560.00000000
12969 1606.00000000