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 (
    12, 162, 159, 158, 240, 238, 239, 245, 
    242, 243, 214, 217, 218, 206, 207, 198, 
    199, 136, 65, 64, 63, 66, 62, 134
  ) 
  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.00057

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": 36.89481354,
      "index_condition": "cscart_product_prices.product_id in (12,162,159,158,240,238,239,245,242,243,214,217,218,206,207,198,199,136,65,64,63,66,62,134)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
12 3600.000000
62 25200.000000
63 22800.000000
64 22800.000000
65 12000.000000
66 46800.000000
134 10800.000000
136 0.000000
158 570000.000000
159 1365000.000000
162 3930000.000000
198 2160.000000
199 3600.000000
206 21600.000000
207 5040.000000
214 116640.000000
217 73320.000000
218 55200.000000
238 66240.000000
239 66240.000000
240 59880.000000
242 29880.000000
243 29880.000000
245 699.000000