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 (
    145, 277, 139, 282, 179, 280, 148, 144, 
    143, 141, 111, 147, 213, 150, 216, 149, 
    258, 146, 233, 193, 225, 129, 383, 131
  ) 
  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.00048

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": 62.74238205,
      "index_condition": "cscart_product_prices.product_id in (145,277,139,282,179,280,148,144,143,141,111,147,213,150,216,149,258,146,233,193,225,129,383,131)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
111 1800.00000000
129 1800.00000000
131 1800.00000000
139 1800.00000000
141 2700.00000000
143 2700.00000000
144 2700.00000000
145 2700.00000000
146 2700.00000000
147 2700.00000000
148 2700.00000000
149 2700.00000000
150 2700.00000000
179 1800.00000000
193 2700.00000000
213 1800.00000000
216 1800.00000000
225 1800.00000000
233 1800.00000000
258 2700.00000000
277 1800.00000000
280 2700.00000000
282 2700.00000000
383 2700.00000000