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 (
    1171, 1324, 1301, 1215, 1439, 1323, 717, 
    1217, 1343, 1338, 1337, 1174, 718, 1339, 
    1417, 341, 1275, 1216, 39, 1798, 1797
  ) 
  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.00126

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": 21,
      "filtered": 4.285713196,
      "index_condition": "cscart_product_prices.product_id in (1171,1324,1301,1215,1439,1323,717,1217,1343,1338,1337,1174,718,1339,1417,341,1275,1216,39,1798,1797)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
39 80000.00000000
341 122000.00000000
717 118000.00000000
718 0.00000000
1171 88000.00000000
1174 91000.00000000
1215 0.00000000
1216 88000.00000000
1217 122000.00000000
1275 0.00000000
1301 63000.00000000
1323 110000.00000000
1324 116000.00000000
1337 88000.00000000
1338 88000.00000000
1339 100000.00000000
1343 116000.00000000
1417 122000.00000000
1439 60000.00000000
1797 50000.00000000
1798 34000.00000000