SELECT 
  f.feature_id, 
  f.purpose, 
  p.product_id, 
  p.parent_product_id, 
  g.id, 
  g.code 
FROM 
  cscart_product_variation_group_features AS f 
  INNER JOIN cscart_product_variation_groups AS g ON f.group_id = g.id 
  INNER JOIN cscart_product_variation_group_products AS p ON f.group_id = p.group_id 
WHERE 
  p.product_id IN (
    90836, 88757, 89452, 89465, 89473, 89481, 
    85734, 89969, 90839, 90841, 91535, 
    87505, 87521, 88454, 88471, 88487, 
    88242, 88246, 89457, 89021, 88978, 
    88995, 87537, 88422, 89839, 89891, 
    89963, 91529, 84701, 88959, 88960, 
    88962, 88523, 87547, 88406, 88676, 
    88723, 88569, 85726, 85743, 85753, 
    85763, 85801, 85802, 87518, 87534, 
    88450, 88467, 88483, 85722, 85739, 
    85749, 85759, 88984, 88193, 88205, 
    88234, 88238, 90837, 89843, 89895, 
    89968, 91534, 85733, 88980, 88997, 
    88662, 88709, 84700, 85670, 85690, 
    85702, 85714, 88495, 88961, 91437, 
    91451, 85719, 88717, 85800, 88755, 
    88756, 85678, 87506, 87517, 87522, 
    87533, 88453, 88470, 88486, 88567, 
    89837, 89889, 89961, 91527, 88522
  )

Query time 0.00082

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "1.05"
    },
    "nested_loop": [
      {
        "table": {
          "table_name": "f",
          "access_type": "ALL",
          "possible_keys": [
            "idx_group_id"
          ],
          "rows_examined_per_scan": 1,
          "rows_produced_per_join": 1,
          "filtered": "100.00",
          "cost_info": {
            "read_cost": "0.25",
            "eval_cost": "0.10",
            "prefix_cost": "0.35",
            "data_read_per_join": "104"
          },
          "used_columns": [
            "feature_id",
            "purpose",
            "group_id"
          ]
        }
      },
      {
        "table": {
          "table_name": "g",
          "access_type": "eq_ref",
          "possible_keys": [
            "PRIMARY"
          ],
          "key": "PRIMARY",
          "used_key_parts": [
            "id"
          ],
          "key_length": "3",
          "ref": [
            "nuie_scalesta_net.f.group_id"
          ],
          "rows_examined_per_scan": 1,
          "rows_produced_per_join": 1,
          "filtered": "100.00",
          "cost_info": {
            "read_cost": "0.25",
            "eval_cost": "0.10",
            "prefix_cost": "0.70",
            "data_read_per_join": "400"
          },
          "used_columns": [
            "id",
            "code"
          ]
        }
      },
      {
        "table": {
          "table_name": "p",
          "access_type": "ref",
          "possible_keys": [
            "PRIMARY",
            "idx_group_id"
          ],
          "key": "idx_group_id",
          "used_key_parts": [
            "group_id"
          ],
          "key_length": "3",
          "ref": [
            "nuie_scalesta_net.f.group_id"
          ],
          "rows_examined_per_scan": 1,
          "rows_produced_per_join": 1,
          "filtered": "100.00",
          "index_condition": "(`nuie_scalesta_net`.`p`.`product_id` in (90836,88757,89452,89465,89473,89481,85734,89969,90839,90841,91535,87505,87521,88454,88471,88487,88242,88246,89457,89021,88978,88995,87537,88422,89839,89891,89963,91529,84701,88959,88960,88962,88523,87547,88406,88676,88723,88569,85726,85743,85753,85763,85801,85802,87518,87534,88450,88467,88483,85722,85739,85749,85759,88984,88193,88205,88234,88238,90837,89843,89895,89968,91534,85733,88980,88997,88662,88709,84700,85670,85690,85702,85714,88495,88961,91437,91451,85719,88717,85800,88755,88756,85678,87506,87517,87522,87533,88453,88470,88486,88567,89837,89889,89961,91527,88522))",
          "cost_info": {
            "read_cost": "0.25",
            "eval_cost": "0.10",
            "prefix_cost": "1.05",
            "data_read_per_join": "16"
          },
          "used_columns": [
            "product_id",
            "parent_product_id",
            "group_id"
          ]
        }
      }
    ]
  }
}