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 (
    337, 335, 334, 329, 330, 331, 325, 319, 
    320, 321, 322, 323
  )

Query time 0.00056

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "55.39"
    },
    "nested_loop": [
      {
        "table": {
          "table_name": "p",
          "access_type": "ALL",
          "possible_keys": [
            "PRIMARY",
            "idx_group_id"
          ],
          "rows_examined_per_scan": 49,
          "rows_produced_per_join": 12,
          "filtered": "24.49",
          "cost_info": {
            "read_cost": "9.52",
            "eval_cost": "2.40",
            "prefix_cost": "11.92",
            "data_read_per_join": "192"
          },
          "used_columns": [
            "product_id",
            "parent_product_id",
            "group_id"
          ],
          "attached_condition": "(`atulecarter_atul_demo1`.`p`.`product_id` in (337,335,334,329,330,331,325,319,320,321,322,323))"
        }
      },
      {
        "table": {
          "table_name": "g",
          "access_type": "eq_ref",
          "possible_keys": [
            "PRIMARY"
          ],
          "key": "PRIMARY",
          "used_key_parts": [
            "id"
          ],
          "key_length": "3",
          "ref": [
            "atulecarter_atul_demo1.p.group_id"
          ],
          "rows_examined_per_scan": 1,
          "rows_produced_per_join": 12,
          "filtered": "100.00",
          "cost_info": {
            "read_cost": "12.00",
            "eval_cost": "2.40",
            "prefix_cost": "26.32",
            "data_read_per_join": "4K"
          },
          "used_columns": [
            "id",
            "code"
          ]
        }
      },
      {
        "table": {
          "table_name": "f",
          "access_type": "ref",
          "possible_keys": [
            "idx_group_id"
          ],
          "key": "idx_group_id",
          "used_key_parts": [
            "group_id"
          ],
          "key_length": "3",
          "ref": [
            "atulecarter_atul_demo1.p.group_id"
          ],
          "rows_examined_per_scan": 2,
          "rows_produced_per_join": 25,
          "filtered": "100.00",
          "cost_info": {
            "read_cost": "24.00",
            "eval_cost": "5.07",
            "prefix_cost": "55.39",
            "data_read_per_join": "2K"
          },
          "used_columns": [
            "feature_id",
            "purpose",
            "group_id"
          ]
        }
      }
    ]
  }
}

Result

feature_id purpose product_id parent_product_id id code
550 group_catalog_item 319 0 15 PV-6E28C72BA
550 group_catalog_item 320 0 15 PV-6E28C72BA
550 group_catalog_item 321 0 15 PV-6E28C72BA
550 group_catalog_item 322 0 15 PV-6E28C72BA
550 group_catalog_item 323 0 15 PV-6E28C72BA
549 group_catalog_item 325 0 16 PV-7C513A520
548 group_variation_catalog_item 325 0 16 PV-7C513A520
550 group_catalog_item 329 0 18 PV-3CA1C5EF1
551 group_catalog_item 329 0 18 PV-3CA1C5EF1
550 group_catalog_item 330 0 18 PV-3CA1C5EF1
551 group_catalog_item 330 0 18 PV-3CA1C5EF1
550 group_catalog_item 331 0 18 PV-3CA1C5EF1
551 group_catalog_item 331 0 18 PV-3CA1C5EF1
551 group_catalog_item 335 0 20 PV-F6AE5E9EE
551 group_catalog_item 334 0 20 PV-F6AE5E9EE
552 group_variation_catalog_item 337 0 21 PV-C29B43E38