SELECT 
  cscart_ult_product_prices.product_id, 
  MIN(
    IF(
      cscart_ult_product_prices.percentage_discount = 0, 
      cscart_ult_product_prices.price, 
      cscart_ult_product_prices.price - (
        cscart_ult_product_prices.price * cscart_ult_product_prices.percentage_discount
      )/ 100
    )
  ) AS price 
FROM 
  cscart_ult_product_prices 
WHERE 
  cscart_ult_product_prices.product_id IN (
    2772, 2773, 2774, 2775, 2776, 2777, 2845, 
    2846, 2847, 2848, 2849, 2850, 2851, 
    2852, 2853, 2854, 2855, 2856, 2857, 
    2858, 2859, 2860, 2861, 2862, 2942, 
    2943, 2944, 2945, 2946, 2947, 2948, 
    2949, 2950, 3037, 3038, 3039, 3040, 
    3041, 3042, 3043, 3044, 3045, 3853, 
    5790, 5791, 5792, 5793, 5794, 5795, 
    5796, 5797, 5798, 6307, 6308, 6309, 
    6310, 6311, 6357, 6358, 6359, 6360, 
    6361, 6362, 6363, 6364, 6365, 6431, 
    6432, 6433, 6434, 6435, 6436, 6437, 
    6438, 6439, 6440, 6441, 6442, 6443, 
    6444, 6445, 6446, 6447, 6526, 6527, 
    6528, 6529, 6530, 6531, 6532, 6533, 
    6534, 6615, 6616, 6617, 6618
  ) 
  AND cscart_ult_product_prices.lower_limit = 1 
  AND cscart_ult_product_prices.company_id = 1 
  AND cscart_ult_product_prices.usergroup_id IN (0, 0, 1) 
GROUP BY 
  cscart_ult_product_prices.product_id

Query time 0.00032

JSON explain

{
  "query_block": {
    "select_id": 1,
    "message": "no matching row in const table"
  }
}