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 (
    88144, 88939, 84702, 84705, 91052, 84697, 
    84698, 88946, 88947, 88948, 88140, 
    88143, 88508, 87890, 88943, 88944, 
    88945, 84695, 88937, 87877, 88515, 
    88518, 88514, 88517, 88511, 87876, 
    88506, 88507, 88510, 90828, 90827, 
    87995, 87882, 87875, 90826, 87881, 
    87874, 87880, 87873, 92893, 92894, 
    93002, 93003, 93004, 93005, 93006, 
    93007, 93008, 93009, 93010, 93011, 
    93012, 93013, 93014, 93015, 93341, 
    93342, 93343, 93344, 93345, 93346, 
    93347, 93348, 93349, 93350, 93351, 
    93352, 93353, 93354, 93355, 93750, 
    93751, 93752, 93848, 93849, 93886, 
    93887, 93888, 93889, 93890, 93891, 
    93892, 93893, 94558, 94559, 94560, 
    94561, 94562, 94563, 94564, 94565, 
    94566, 94567, 94568, 94569, 94570
  )

Query time 0.00067

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 (88144,88939,84702,84705,91052,84697,84698,88946,88947,88948,88140,88143,88508,87890,88943,88944,88945,84695,88937,87877,88515,88518,88514,88517,88511,87876,88506,88507,88510,90828,90827,87995,87882,87875,90826,87881,87874,87880,87873,92893,92894,93002,93003,93004,93005,93006,93007,93008,93009,93010,93011,93012,93013,93014,93015,93341,93342,93343,93344,93345,93346,93347,93348,93349,93350,93351,93352,93353,93354,93355,93750,93751,93752,93848,93849,93886,93887,93888,93889,93890,93891,93892,93893,94558,94559,94560,94561,94562,94563,94564,94565,94566,94567,94568,94569,94570))",
          "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"
          ]
        }
      }
    ]
  }
}