[
  {
    "db_id": "restaurant_bills",
    "question": "How many customers are there?",
    "query": "SELECT count(*) FROM customer",
    "query_output": 8,
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | length"
        ],
        "candidates": {
          ".customers | length": [
            8
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Count the number of customers.",
    "query": "SELECT count(*) FROM customer",
    "query_output": 8,
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | length"
        ],
        "candidates": {
          ".customers | length": [
            8
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "List the names of customers in ascending order of level of membership.",
    "query": "SELECT Name FROM customer ORDER BY Level_of_Membership ASC",
    "query_output": [
      "Len Hutton",
      "Cyril Washbrook",
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett",
      "Denis Compton",
      "Donald Bradman",
      "Arthur Morris"
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .[]"
        ],
        "candidates": {
          ".customers | sort_by(.Level_of_Membership) | map(.Name)": [
            [
              "Len Hutton",
              "Cyril Washbrook",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett",
              "Denis Compton",
              "Donald Bradman",
              "Arthur Morris"
            ]
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .": [
            [
              "Len Hutton",
              "Cyril Washbrook",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett",
              "Denis Compton",
              "Donald Bradman",
              "Arthur Morris"
            ]
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .[]": [
            "Len Hutton",
            "Cyril Washbrook",
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett",
            "Denis Compton",
            "Donald Bradman",
            "Arthur Morris"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Sort all the customers by the level of membership in ascending order, and return the customer names.",
    "query": "SELECT Name FROM customer ORDER BY Level_of_Membership ASC",
    "query_output": [
      "Len Hutton",
      "Cyril Washbrook",
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett",
      "Denis Compton",
      "Donald Bradman",
      "Arthur Morris"
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .[]"
        ],
        "candidates": {
          ".customers | sort_by(.Level_of_Membership) | map(.Name)": [
            [
              "Len Hutton",
              "Cyril Washbrook",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett",
              "Denis Compton",
              "Donald Bradman",
              "Arthur Morris"
            ]
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .": [
            [
              "Len Hutton",
              "Cyril Washbrook",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett",
              "Denis Compton",
              "Donald Bradman",
              "Arthur Morris"
            ]
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | [.]": [
            [
              [
                "Len Hutton",
                "Cyril Washbrook",
                "Sid Barnes",
                "Bill Edrich",
                "Lindsay Hassett",
                "Denis Compton",
                "Donald Bradman",
                "Arthur Morris"
              ]
            ]
          ],
          "[.customers | sort_by(.Level_of_Membership) | map(.Name)][0]": [
            [
              "Len Hutton",
              "Cyril Washbrook",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett",
              "Denis Compton",
              "Donald Bradman",
              "Arthur Morris"
            ]
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | .[]": [
            "Len Hutton",
            "Cyril Washbrook",
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett",
            "Denis Compton",
            "Donald Bradman",
            "Arthur Morris"
          ],
          ".customers | sort_by(.Level_of_Membership) | map(.Name) | first": [
            "Len Hutton"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "What are the nationalities and card credits of customers?",
    "query": "SELECT Nationality ,  Card_Credit FROM customer",
    "query_output": [
      {
        "Nationality": "Australia",
        "Card_Credit": 87.0
      },
      {
        "Nationality": "England",
        "Card_Credit": 62.44
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 72.57
      },
      {
        "Nationality": "England",
        "Card_Credit": 50.85
      },
      {
        "Nationality": "England",
        "Card_Credit": 42.75
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 82.25
      },
      {
        "Nationality": "England",
        "Card_Credit": 31.9
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 44.28
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers | map({Nationality, Card_Credit})": [
            [
              {
                "Nationality": "Australia",
                "Card_Credit": 87
              },
              {
                "Nationality": "England",
                "Card_Credit": 62.44
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 72.57
              },
              {
                "Nationality": "England",
                "Card_Credit": 50.85
              },
              {
                "Nationality": "England",
                "Card_Credit": 42.75
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 82.25
              },
              {
                "Nationality": "England",
                "Card_Credit": 31.9
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 44.28
              }
            ]
          ],
          ".customers[] | {Nationality, Card_Credit}": [
            {
              "Nationality": "Australia",
              "Card_Credit": 87
            },
            {
              "Nationality": "England",
              "Card_Credit": 62.44
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 72.57
            },
            {
              "Nationality": "England",
              "Card_Credit": 50.85
            },
            {
              "Nationality": "England",
              "Card_Credit": 42.75
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 82.25
            },
            {
              "Nationality": "England",
              "Card_Credit": 31.9
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 44.28
            }
          ],
          ".customers | map({Nationality, Card_Credit: (.Card_Credit * 1.0)})": [
            [
              {
                "Nationality": "Australia",
                "Card_Credit": 87
              },
              {
                "Nationality": "England",
                "Card_Credit": 62.44
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 72.57
              },
              {
                "Nationality": "England",
                "Card_Credit": 50.85
              },
              {
                "Nationality": "England",
                "Card_Credit": 42.75
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 82.25
              },
              {
                "Nationality": "England",
                "Card_Credit": 31.9
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 44.28
              }
            ]
          ],
          ".customers | map({Nationality, Card_Credit: (.Card_Credit|tostring|tonumber)})": [
            [
              {
                "Nationality": "Australia",
                "Card_Credit": 87
              },
              {
                "Nationality": "England",
                "Card_Credit": 62.44
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 72.57
              },
              {
                "Nationality": "England",
                "Card_Credit": 50.85
              },
              {
                "Nationality": "England",
                "Card_Credit": 42.75
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 82.25
              },
              {
                "Nationality": "England",
                "Card_Credit": 31.9
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 44.28
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    # We select Nationality and Card_Credit from each customer in the list\n    return [\n        {\"Nationality\": customer[\"Nationality\"], \"Card_Credit\": customer[\"Card_Credit\"]}\n        for customer in data.get(\"customers\", [])\n    ]"
        ],
        "candidates": {
          "def transform(data):\n    # We select Nationality and Card_Credit from each customer in the list\n    return [\n        {\"Nationality\": customer[\"Nationality\"], \"Card_Credit\": customer[\"Card_Credit\"]}\n        for customer in data.get(\"customers\", [])\n    ]": [
            {
              "Nationality": "Australia",
              "Card_Credit": 87.0
            },
            {
              "Nationality": "England",
              "Card_Credit": 62.44
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 72.57
            },
            {
              "Nationality": "England",
              "Card_Credit": 50.85
            },
            {
              "Nationality": "England",
              "Card_Credit": 42.75
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 82.25
            },
            {
              "Nationality": "England",
              "Card_Credit": 31.9
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 44.28
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Find the nationality and card credit of each customer.",
    "query": "SELECT Nationality ,  Card_Credit FROM customer",
    "query_output": [
      {
        "Nationality": "Australia",
        "Card_Credit": 87.0
      },
      {
        "Nationality": "England",
        "Card_Credit": 62.44
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 72.57
      },
      {
        "Nationality": "England",
        "Card_Credit": 50.85
      },
      {
        "Nationality": "England",
        "Card_Credit": 42.75
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 82.25
      },
      {
        "Nationality": "England",
        "Card_Credit": 31.9
      },
      {
        "Nationality": "Australia",
        "Card_Credit": 44.28
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers[] | {Nationality, Card_Credit}": [
            {
              "Nationality": "Australia",
              "Card_Credit": 87
            },
            {
              "Nationality": "England",
              "Card_Credit": 62.44
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 72.57
            },
            {
              "Nationality": "England",
              "Card_Credit": 50.85
            },
            {
              "Nationality": "England",
              "Card_Credit": 42.75
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 82.25
            },
            {
              "Nationality": "England",
              "Card_Credit": 31.9
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 44.28
            }
          ],
          ".customers | map({Nationality, Card_Credit})": [
            [
              {
                "Nationality": "Australia",
                "Card_Credit": 87
              },
              {
                "Nationality": "England",
                "Card_Credit": 62.44
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 72.57
              },
              {
                "Nationality": "England",
                "Card_Credit": 50.85
              },
              {
                "Nationality": "England",
                "Card_Credit": 42.75
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 82.25
              },
              {
                "Nationality": "England",
                "Card_Credit": 31.9
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 44.28
              }
            ]
          ],
          ".customers[] | {Nationality, Card_Credit: (.Card_Credit | tonumber)}": [
            {
              "Nationality": "Australia",
              "Card_Credit": 87
            },
            {
              "Nationality": "England",
              "Card_Credit": 62.44
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 72.57
            },
            {
              "Nationality": "England",
              "Card_Credit": 50.85
            },
            {
              "Nationality": "England",
              "Card_Credit": 42.75
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 82.25
            },
            {
              "Nationality": "England",
              "Card_Credit": 31.9
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 44.28
            }
          ],
          "[.customers[] | {Nationality, Card_Credit}]": [
            [
              {
                "Nationality": "Australia",
                "Card_Credit": 87
              },
              {
                "Nationality": "England",
                "Card_Credit": 62.44
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 72.57
              },
              {
                "Nationality": "England",
                "Card_Credit": 50.85
              },
              {
                "Nationality": "England",
                "Card_Credit": 42.75
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 82.25
              },
              {
                "Nationality": "England",
                "Card_Credit": 31.9
              },
              {
                "Nationality": "Australia",
                "Card_Credit": 44.28
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    # We expect data['customers'] to be a list of customers\n    return [\n        {\n            \"Nationality\": customer[\"Nationality\"],\n            \"Card_Credit\": customer[\"Card_Credit\"]\n        }\n        for customer in data.get(\"customers\", [])\n    ]"
        ],
        "candidates": {
          "def transform(data):\n    # We expect data['customers'] to be a list of customers\n    return [\n        {\n            \"Nationality\": customer[\"Nationality\"],\n            \"Card_Credit\": customer[\"Card_Credit\"]\n        }\n        for customer in data.get(\"customers\", [])\n    ]": [
            {
              "Nationality": "Australia",
              "Card_Credit": 87.0
            },
            {
              "Nationality": "England",
              "Card_Credit": 62.44
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 72.57
            },
            {
              "Nationality": "England",
              "Card_Credit": 50.85
            },
            {
              "Nationality": "England",
              "Card_Credit": 42.75
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 82.25
            },
            {
              "Nationality": "England",
              "Card_Credit": 31.9
            },
            {
              "Nationality": "Australia",
              "Card_Credit": 44.28
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the names of customers with nationality \"England\" or \"Australia\".",
    "query": "SELECT Name FROM customer WHERE Nationality  =  \"England\" OR Nationality  =  \"Australia\"",
    "query_output": [
      "Arthur Morris",
      "Denis Compton",
      "Donald Bradman",
      "Cyril Washbrook",
      "Len Hutton",
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett"
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)\n| .": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)\n| first": [
            "Arthur Morris"
          ],
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)\n| flatten": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    return [\n        customer['Name']\n        for customer in data.get('customers', [])\n        if customer.get('Nationality') in ('England', 'Australia')\n    ]"
        ],
        "candidates": {
          "def transform(data):\n    return [\n        customer['Name']\n        for customer in data.get('customers', [])\n        if customer.get('Nationality') in ('England', 'Australia')\n    ]": [
            "Arthur Morris",
            "Denis Compton",
            "Donald Bradman",
            "Cyril Washbrook",
            "Len Hutton",
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Which customers have nationality \"England\" or \"Australia\"? Give me their names.",
    "query": "SELECT Name FROM customer WHERE Nationality  =  \"England\" OR Nationality  =  \"Australia\"",
    "query_output": [
      "Arthur Morris",
      "Denis Compton",
      "Donald Bradman",
      "Cyril Washbrook",
      "Len Hutton",
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett"
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers[] | select(.Nationality == \"England\" or .Nationality == \"Australia\") | .Name"
        ],
        "candidates": {
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers\n| map(select(.Nationality == \"England\" or .Nationality == \"Australia\").Name)\n| flatten": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers\n| [ .[] | select(.Nationality == \"England\" or .Nationality == \"Australia\") | .Name ]": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          "[ .customers[] | select(.Nationality == \"England\" or .Nationality == \"Australia\") | .Name ]": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Donald Bradman",
              "Cyril Washbrook",
              "Len Hutton",
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers[] | select(.Nationality == \"England\" or .Nationality == \"Australia\") | .Name": [
            "Arthur Morris",
            "Denis Compton",
            "Donald Bradman",
            "Cyril Washbrook",
            "Len Hutton",
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "What is the average card credit of customers with membership level higher than 1?",
    "query": "SELECT avg(Card_Credit) FROM customer WHERE Level_of_Membership  >  1",
    "query_output": 74.00333333333333,
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| map(select(.Level_of_Membership > 1) | .Card_Credit)\n| if length == 0 then null else add/length end"
        ],
        "candidates": {
          ".customers\n| map(select(.Level_of_Membership > 1) | .Card_Credit)\n| if length == 0 then null else add/length end": [
            74.00333333333333
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Find the average card credit customers whose membership level is above 1.",
    "query": "SELECT avg(Card_Credit) FROM customer WHERE Level_of_Membership  >  1",
    "query_output": 74.00333333333333,
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| map(select(.Level_of_Membership > 1) | .Card_Credit)\n| if length == 0 then null else (add / length) end"
        ],
        "candidates": {
          ".customers\n| map(select(.Level_of_Membership > 1) | .Card_Credit)\n| if length == 0 then null else (add / length) end": [
            74.00333333333333
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "What is the card credit of the customer with the highest membership level?",
    "query": "SELECT Card_Credit FROM customer ORDER BY Level_of_Membership DESC LIMIT 1",
    "query_output": 87.0,
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers | max_by(.Level_of_Membership) | .Card_Credit": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit | tonumber": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit | . + 0.0": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | {result: .Card_Credit} | .result + 0.0": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit / 1": [
            87
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    customers = data.get('customers', [])\n    if not customers:\n        return None\n    # Sort by Level_of_Membership descending, get first customer's Card_Credit\n    customer = max(customers, key=lambda x: x.get('Level_of_Membership', float('-inf')))\n    return customer.get('Card_Credit')"
        ],
        "candidates": {
          "def transform(data):\n    customers = data.get('customers', [])\n    if not customers:\n        return None\n    # Sort by Level_of_Membership descending, get first customer's Card_Credit\n    customer = max(customers, key=lambda x: x.get('Level_of_Membership', float('-inf')))\n    return customer.get('Card_Credit')": 87.0
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Find the customer with the highest membership level and return his or her card credit.",
    "query": "SELECT Card_Credit FROM customer ORDER BY Level_of_Membership DESC LIMIT 1",
    "query_output": 87.0,
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers | max_by(.Level_of_Membership) | .Card_Credit": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit | tonumber": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit | . + 0.0": [
            87
          ],
          ".customers | max_by(.Level_of_Membership) | .Card_Credit | [.] | .[0] * 1.0": [
            87
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    # Get the list of customers\n    customers = data.get('customers', [])\n    # Sort the customers by Level_of_Membership descending, get the first\n    if not customers:\n        return None\n    top_customer = max(customers, key=lambda x: x.get('Level_of_Membership', float('-inf')))\n    return top_customer.get('Card_Credit')"
        ],
        "candidates": {
          "def transform(data):\n    # Get the list of customers\n    customers = data.get('customers', [])\n    # Sort the customers by Level_of_Membership descending, get the first\n    if not customers:\n        return None\n    top_customer = max(customers, key=lambda x: x.get('Level_of_Membership', float('-inf')))\n    return top_customer.get('Card_Credit')": 87.0
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show different nationalities of customers, along with the number of customers of each nationality.",
    "query": "SELECT Nationality ,  COUNT(*) FROM customer GROUP BY Nationality",
    "query_output": [
      {
        "Nationality": "Australia",
        "COUNT(*)": 4
      },
      {
        "Nationality": "England",
        "COUNT(*)": 4
      }
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})\n| .[]"
        ],
        "candidates": {
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})": [
            [
              {
                "Nationality": "Australia",
                "COUNT(*)": 4
              },
              {
                "Nationality": "England",
                "COUNT(*)": 4
              }
            ]
          ],
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})\n| .": [
            [
              {
                "Nationality": "Australia",
                "COUNT(*)": 4
              },
              {
                "Nationality": "England",
                "COUNT(*)": 4
              }
            ]
          ],
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})\n| .[]": [
            {
              "Nationality": "Australia",
              "COUNT(*)": 4
            },
            {
              "Nationality": "England",
              "COUNT(*)": 4
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "How many customers are associated with each nationality? List the nationality and the number of customers.",
    "query": "SELECT Nationality ,  COUNT(*) FROM customer GROUP BY Nationality",
    "query_output": [
      {
        "Nationality": "Australia",
        "COUNT(*)": 4
      },
      {
        "Nationality": "England",
        "COUNT(*)": 4
      }
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})\n| .[]"
        ],
        "candidates": {
          ".customers \n| group_by(.Nationality) \n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})": [
            [
              {
                "Nationality": "Australia",
                "COUNT(*)": 4
              },
              {
                "Nationality": "England",
                "COUNT(*)": 4
              }
            ]
          ],
          ".customers \n| group_by(.Nationality) \n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length}) \n| .": [
            [
              {
                "Nationality": "Australia",
                "COUNT(*)": 4
              },
              {
                "Nationality": "England",
                "COUNT(*)": 4
              }
            ]
          ],
          ".customers\n| group_by(.Nationality)\n| map({Nationality: .[0].Nationality, \"COUNT(*)\": length})\n| .[]": [
            {
              "Nationality": "Australia",
              "COUNT(*)": 4
            },
            {
              "Nationality": "England",
              "COUNT(*)": 4
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the most common nationality of customers.",
    "query": "SELECT Nationality FROM customer GROUP BY Nationality ORDER BY COUNT(*) DESC LIMIT 1",
    "query_output": "England",
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | map(.Nationality) | group_by(.) | max_by(length) | .[0]"
        ],
        "candidates": {
          ".customers | map(.Nationality) | group_by(.) | max_by(length) | .[0]": [
            "England"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Which nationality does the most customers have?",
    "query": "SELECT Nationality FROM customer GROUP BY Nationality ORDER BY COUNT(*) DESC LIMIT 1",
    "query_output": "England",
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| group_by(.Nationality)\n| max_by(length)\n| .[0].Nationality",
          ".customers\n| group_by(.Nationality)\n| map({nationality: .[0].Nationality, count: length})\n| max_by(.count)\n| .nationality"
        ],
        "candidates": {
          ".customers\n| group_by(.Nationality)\n| max_by(length)\n| .[0].Nationality": [
            "England"
          ],
          ".customers\n| group_by(.Nationality)\n| sort_by(-length)\n| .[0][0].Nationality": [
            "Australia"
          ],
          ".customers\n| group_by(.Nationality)\n| map({nationality: .[0].Nationality, count: length})\n| max_by(.count)\n| .nationality": [
            "England"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the nations that have both customers with card credit smaller than 50 and customers with card credit bigger than 75.",
    "query": "SELECT Nationality FROM customer WHERE Card_Credit  <  50 INTERSECT SELECT Nationality FROM customer WHERE Card_Credit  >  75",
    "query_output": "Australia",
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          "(\n  .customers\n  | group_by(.Nationality)\n  | map(\n      {\n        nationality: .[0].Nationality,\n        any_low: any(.Card_Credit < 50),\n        any_high: any(.Card_Credit > 75)\n      }\n    )\n  | map(select(.any_low and .any_high) | .nationality)\n  | .[]\n)"
        ],
        "candidates": {
          "(\n  .customers\n  | group_by(.Nationality)\n  | map(\n      {\n        nationality: .[0].Nationality,\n        any_low: any(.Card_Credit < 50),\n        any_high: any(.Card_Credit > 75)\n      }\n    )\n  | map(select(.any_low and .any_high) | .nationality)\n  | .[]\n)": [
            "Australia"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Which nations have both customers with card credit above 50 and customers with card credit below 75.",
    "query": "SELECT Nationality FROM customer WHERE Card_Credit  <  50 INTERSECT SELECT Nationality FROM customer WHERE Card_Credit  >  75",
    "query_output": "Australia",
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| group_by(.Nationality)\n| map(select(\n    (map(.Card_Credit < 50) | any)\n    and\n    (map(.Card_Credit > 75) | any)\n))\n| map(.[0].Nationality)\n| .[0]"
        ],
        "candidates": {
          "[\n  .customers\n  | group_by(.Nationality)\n  | map({\n      nationality: .[0].Nationality,\n      has_below_75: any(.[]; .Card_Credit < 75),\n      has_above_50: any(.[]; .Card_Credit > 50)\n    })\n  | map(select(.has_below_75 and .has_above_50))\n  | map(.nationality)\n  | .[]\n]": [
            [
              "Australia",
              "England"
            ]
          ],
          ".customers\n| group_by(.Nationality)\n| map(select(\n    (map(.Card_Credit < 75) | any) and \n    (map(.Card_Credit > 50) | any)\n))\n| map(.[0].Nationality)\n| .[]": [
            "Australia",
            "England"
          ],
          "[\n  .customers\n  | group_by(.Nationality)\n  | map(select(\n      (map(.Card_Credit < 50) | any) \n      and \n      (map(.Card_Credit > 75) | any)\n    ))\n  | map(.[0].Nationality)\n  | .[]\n]": [
            [
              "Australia"
            ]
          ],
          ".customers\n| group_by(.Nationality)\n| map(select(\n    (map(.Card_Credit < 50) | any)\n    and\n    (map(.Card_Credit > 75) | any)\n))\n| map(.[0].Nationality)\n| .[0]": [
            "Australia"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the names of customers and names of dishes they order.",
    "query": "SELECT T1.Name ,  T2.Dish_Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "Dish_Name": "Spring Rolls"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Kung Pao Chicken"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Ma Po Tofu"
      },
      {
        "Name": "Donald Bradman",
        "Dish_Name": "Peking Roasted Duck"
      },
      {
        "Name": "Cyril Washbrook",
        "Dish_Name": "Chow Mein"
      },
      {
        "Name": "Len Hutton",
        "Dish_Name": "Chow Mein"
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map(\n    .orders[]? as $order\n    | {Name: .Name, Dish_Name: $order.Dish_Name}\n)\n| flatten": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(select(.orders != null) | . as $c | .orders[] | {Name: $c.Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(\n    if .orders != null then\n      (.orders[] | {Name: .Name, Dish_Name})\n    else empty\n    end\n)\n| flatten": [
            [
              {
                "Name": null,
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": null,
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": null,
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": null,
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": null,
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": null,
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers \n| map(. as $c | (if (.orders != null) then .orders[] | {Name: $c.Name, Dish_Name} else empty end))\n| flatten": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(. as $c | (.orders // []) | map({Name: $c.Name, Dish_Name}))\n| flatten": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers[]\n| . as $c\n| (.orders // [])\n| map({Name: $c.Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              }
            ],
            [
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              }
            ],
            [
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              }
            ],
            [
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              }
            ],
            [
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ],
            [],
            [],
            []
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    results = []\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        for order in customer.get(\"orders\", []):\n            dish_name = order.get(\"Dish_Name\")\n            results.append({\"Name\": name, \"Dish_Name\": dish_name})\n    return results": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    results = []\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        for order in customer.get(\"orders\", []):\n            # The SQL was a JOIN on customer_id, so we list all orders for each customer.\n            results.append({\"Name\": name, \"Dish_Name\": order.get(\"Dish_Name\")})\n    # Sort result for deterministic output matching the SQL join (which has no ORDER BY, but usually returns by join order)\n    return sorted(results, key=lambda x: (x[\"Name\"], x[\"Dish_Name\"]))": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    results = []\n    # The expected output order is as they appear in the input JSON (joined order, not sorted by name)\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        for order in customer.get(\"orders\", []):\n            # The expected output should match the real JSON order, so do NOT sort\n            results.append({\"Name\": name, \"Dish_Name\": order.get(\"Dish_Name\")})\n    return results": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    results = []\n    # We need to process customers in input order,\n    # and process each customer's orders in the same order as in input.\n    # The mismatch is likely due to the expected order: the second record must be Denis Compton with \"Kung Pao Chicken\".\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        # To ensure we only add the correct customer/order combinations, \n        # look for Denis Compton's \"Kung Pao Chicken\" in the expected output.\n        # However, to generalize, just yield all (customer, each order).\n        for order in customer.get(\"orders\", []):\n            # Check if order has a Dish_Name (should always be present if schema is respected)\n            if \"Dish_Name\" in order:\n                results.append({\"Name\": name, \"Dish_Name\": order[\"Dish_Name\"]})\n    return results": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "For each order, return the customer name and the dish name.",
    "query": "SELECT T1.Name ,  T2.Dish_Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "Dish_Name": "Spring Rolls"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Kung Pao Chicken"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Ma Po Tofu"
      },
      {
        "Name": "Donald Bradman",
        "Dish_Name": "Peking Roasted Duck"
      },
      {
        "Name": "Cyril Washbrook",
        "Dish_Name": "Chow Mein"
      },
      {
        "Name": "Len Hutton",
        "Dish_Name": "Chow Mein"
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map(\n    . as $cust\n    | ( .orders // [] )\n      | map({\n            Name: $cust.Name,\n            Dish_Name: .Dish_Name\n        })\n)\n| flatten": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(\n    {Name} as $c\n    | (.orders // [])\n    | map({Name: $c.Name, Dish_Name})\n)\n| add": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(\n    ( .Name as $name\n      | (.orders // [])\n      | map({Name: $name, Dish_Name: .Dish_Name})\n    )\n)\n| flatten": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(\n    if .orders then\n        .orders | map({Name: .Name, Dish_Name})\n    else\n        []\n    end\n)\n| add": [
            [
              {
                "Name": null,
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": null,
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": null,
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": null,
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": null,
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": null,
                "Dish_Name": "Chow Mein"
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    result = []\n    for customer in data.get('customers', []):\n        name = customer.get('Name')\n        for order in customer.get('orders', []):\n            dish_name = order.get('Dish_Name')\n            result.append({'Name': name, 'Dish_Name': dish_name})\n    return result": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    result = []\n    for customer in data.get('customers', []):\n        name = customer.get('Name')\n        orders = customer.get('orders', [])\n        for order in orders:\n            # Match only those orders where the Dish_Name field exists and is not null\n            if 'Dish_Name' in order and order['Dish_Name'] is not None:\n                result.append({'Name': name, 'Dish_Name': order['Dish_Name']})\n    return result": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    result = []\n    # The expected output order is likely the order of all orders, not per customer,\n    # so we need to keep the overall order as in customer_order table (flat order list)\n    # But the data is denormalised: customer.orders is embedded\n    # We'll flatten all orders, saving customer name and order\n    orders_flat = []\n    for customer in data.get('customers', []):\n        name = customer.get('Name')\n        for order in customer.get('orders', []):\n            # Add also a tie-breaker/customer_order row id: index in orders\n            orders_flat.append((order, name))\n    # Try to sort by how customer_order would have listed (preserving input order)\n    # There might not be enough info, so just use this order\n    result = [{'Name': name, 'Dish_Name': order['Dish_Name']} for order, name in orders_flat]\n    return result": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          "def transform(data):\n    # To mimic the SQL result, join on Customer_ID between customers and their orders, flattening all orders\n    # But the output order must match that of the expected result\n    # We need to iterate in the order: for each customer_order (i.e., all orders for all customers, in order of customers in list, and within those, in order of orders in list)\n    # For each order, use the corresponding customer Customer_ID to get the name\n    # The expected output suggests: [\"Arthur Morris\", \"Spring Rolls\"], [\"Denis Compton\", \"Kung Pao Chicken\"] ...\n    result = []\n    for customer in data.get('customers', []):\n        name = customer.get('Name')\n        for order in customer.get('orders', []):\n            # Using only the first order per customer would be incorrect; so add each order as a row\n            # The string in the EXAMPLE output is \"Kung Pao Chicken\" for \"Denis Compton\"\n            # So we must trust the given JSON has exactly matching data\n            result.append({\n                'Name': name,\n                'Dish_Name': order.get('Dish_Name')\n            })\n    return result": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the names of customers and names of dishes they order, in descending order of the quantity of dish.",
    "query": "SELECT T1.Name ,  T2.Dish_Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID ORDER BY T2.Quantity DESC",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "Dish_Name": "Spring Rolls"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Kung Pao Chicken"
      },
      {
        "Name": "Cyril Washbrook",
        "Dish_Name": "Chow Mein"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Ma Po Tofu"
      },
      {
        "Name": "Donald Bradman",
        "Dish_Name": "Peking Roasted Duck"
      },
      {
        "Name": "Len Hutton",
        "Dish_Name": "Chow Mein"
      }
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})\n| .[]",
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})[]"
        ],
        "candidates": {
          ".customers\n| map(\n    . as $c\n    | ( .orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity}) )\n)\n| flatten\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})\n| .": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          "(.customers\n | map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n | add\n | sort_by(-.Quantity)\n | map({Name, Dish_Name}))": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})\n| .[]": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ],
          ".customers\n| map(. as $c | (.orders // [] | map({Name: $c.Name, Dish_Name: .Dish_Name, Quantity: .Quantity})))\n| add\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})[]": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "For each order, find the customer name and the dish name. Sort the result in descending order of the quantity of dish.",
    "query": "SELECT T1.Name ,  T2.Dish_Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID ORDER BY T2.Quantity DESC",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "Dish_Name": "Spring Rolls"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Kung Pao Chicken"
      },
      {
        "Name": "Cyril Washbrook",
        "Dish_Name": "Chow Mein"
      },
      {
        "Name": "Denis Compton",
        "Dish_Name": "Ma Po Tofu"
      },
      {
        "Name": "Donald Bradman",
        "Dish_Name": "Peking Roasted Duck"
      },
      {
        "Name": "Len Hutton",
        "Dish_Name": "Chow Mein"
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map(select(.orders != null) | . as $c | .orders[] | {Name: $c.Name, Dish_Name, Quantity})\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          ".customers\n| map(select(.orders != null) | . as $c | .orders[] | {Name: $c.Name, Dish_Name, Quantity})\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})\n| .": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ],
          "[\n  .customers[]\n  | select(.orders != null)\n  | . as $c\n  | .orders[]\n  | {Name: $c.Name, Dish_Name, Quantity}\n]\n| sort_by(-.Quantity)\n| map({Name, Dish_Name})": [
            [
              {
                "Name": "Arthur Morris",
                "Dish_Name": "Spring Rolls"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Kung Pao Chicken"
              },
              {
                "Name": "Cyril Washbrook",
                "Dish_Name": "Chow Mein"
              },
              {
                "Name": "Denis Compton",
                "Dish_Name": "Ma Po Tofu"
              },
              {
                "Name": "Donald Bradman",
                "Dish_Name": "Peking Roasted Duck"
              },
              {
                "Name": "Len Hutton",
                "Dish_Name": "Chow Mein"
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    # Collect all (customer name, dish name, quantity) for each order\n    results = []\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        for order in customer.get(\"orders\", []):\n            results.append({\n                \"Name\": name,\n                \"Dish_Name\": order.get(\"Dish_Name\"),\n                \"Quantity\": order.get(\"Quantity\", 0)\n            })\n    # Sort by quantity DESC\n    results.sort(key=lambda x: -x[\"Quantity\"])\n    # Remove quantity from output\n    return [{\"Name\": r[\"Name\"], \"Dish_Name\": r[\"Dish_Name\"]} for r in results]"
        ],
        "candidates": {
          "def transform(data):\n    # Collect all (customer name, dish name, quantity) for each order\n    results = []\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        for order in customer.get(\"orders\", []):\n            results.append({\n                \"Name\": name,\n                \"Dish_Name\": order.get(\"Dish_Name\"),\n                \"Quantity\": order.get(\"Quantity\", 0)\n            })\n    # Sort by quantity DESC\n    results.sort(key=lambda x: -x[\"Quantity\"])\n    # Remove quantity from output\n    return [{\"Name\": r[\"Name\"], \"Dish_Name\": r[\"Dish_Name\"]} for r in results]": [
            {
              "Name": "Arthur Morris",
              "Dish_Name": "Spring Rolls"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Kung Pao Chicken"
            },
            {
              "Name": "Cyril Washbrook",
              "Dish_Name": "Chow Mein"
            },
            {
              "Name": "Denis Compton",
              "Dish_Name": "Ma Po Tofu"
            },
            {
              "Name": "Donald Bradman",
              "Dish_Name": "Peking Roasted Duck"
            },
            {
              "Name": "Len Hutton",
              "Dish_Name": "Chow Mein"
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show each customer name and the total quantities of dishes ordered by that customer.",
    "query": "SELECT T1.Name ,  sum(T2.Quantity) FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID GROUP BY T1.Name",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "sum(T2.Quantity)": 4
      },
      {
        "Name": "Cyril Washbrook",
        "sum(T2.Quantity)": 2
      },
      {
        "Name": "Denis Compton",
        "sum(T2.Quantity)": 3
      },
      {
        "Name": "Donald Bradman",
        "sum(T2.Quantity)": 1
      },
      {
        "Name": "Len Hutton",
        "sum(T2.Quantity)": 1
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map({\n    Name: .Name,\n    \"sum(T2.Quantity)\": (.orders // [] | map(.Quantity) | add)\n})": [
            [
              {
                "Name": "Arthur Morris",
                "sum(T2.Quantity)": 4
              },
              {
                "Name": "Denis Compton",
                "sum(T2.Quantity)": 3
              },
              {
                "Name": "Donald Bradman",
                "sum(T2.Quantity)": 1
              },
              {
                "Name": "Cyril Washbrook",
                "sum(T2.Quantity)": 2
              },
              {
                "Name": "Len Hutton",
                "sum(T2.Quantity)": 1
              },
              {
                "Name": "Sid Barnes",
                "sum(T2.Quantity)": null
              },
              {
                "Name": "Bill Edrich",
                "sum(T2.Quantity)": null
              },
              {
                "Name": "Lindsay Hassett",
                "sum(T2.Quantity)": null
              }
            ]
          ],
          ".customers\n| map({\n    Name: .Name,\n    \"sum(T2.Quantity)\": (.orders // [] | map(.Quantity) | add)\n})\n| group_by(.Name)\n| map({\n    Name: .[0].Name,\n    \"sum(T2.Quantity)\": (map(.\"sum(T2.Quantity)\") | add)\n})": [
            [
              {
                "Name": "Arthur Morris",
                "sum(T2.Quantity)": 4
              },
              {
                "Name": "Bill Edrich",
                "sum(T2.Quantity)": null
              },
              {
                "Name": "Cyril Washbrook",
                "sum(T2.Quantity)": 2
              },
              {
                "Name": "Denis Compton",
                "sum(T2.Quantity)": 3
              },
              {
                "Name": "Donald Bradman",
                "sum(T2.Quantity)": 1
              },
              {
                "Name": "Len Hutton",
                "sum(T2.Quantity)": 1
              },
              {
                "Name": "Lindsay Hassett",
                "sum(T2.Quantity)": null
              },
              {
                "Name": "Sid Barnes",
                "sum(T2.Quantity)": null
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        total_quantity = 0\n        for order in customer.get(\"orders\", []):\n            total_quantity += order.get(\"Quantity\", 0)\n        result.append({\"Name\": customer[\"Name\"], \"sum(T2.Quantity)\": total_quantity})\n    return result": [
            {
              "Name": "Arthur Morris",
              "sum(T2.Quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(T2.Quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(T2.Quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Sid Barnes",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Bill Edrich",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Lindsay Hassett",
              "sum(T2.Quantity)": 0
            }
          ],
          "def transform(data):\n    # We want to sum quantities by customer name, grouping by Name as in SQL\n    from collections import defaultdict\n\n    name_to_qty = defaultdict(int)\n    for customer in data.get(\"customers\", []):\n        name = customer[\"Name\"]\n        orders = customer.get(\"orders\", [])\n        for order in orders:\n            name_to_qty[name] += order.get(\"Quantity\", 0)\n\n    # Order of SQL output is usually by Name as encountered unless otherwise requested,\n    # so we keep the customers' name order as in data\n    names_in_order = []\n    for customer in data.get(\"customers\", []):\n        name = customer[\"Name\"]\n        if name not in names_in_order:\n            names_in_order.append(name)\n    result = []\n    for name in names_in_order:\n        result.append({\"Name\": name, \"sum(T2.Quantity)\": name_to_qty[name]})\n    return result": [
            {
              "Name": "Arthur Morris",
              "sum(T2.Quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(T2.Quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(T2.Quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Sid Barnes",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Bill Edrich",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Lindsay Hassett",
              "sum(T2.Quantity)": 0
            }
          ],
          "def transform(data):\n    # Build a list of (Customer_ID, Name) in order of appearance, skipping duplicates\n    customer_id_name = []\n    seen_ids = set()\n    for customer in data.get(\"customers\", []):\n        cid = customer[\"Customer_ID\"]\n        name = customer[\"Name\"]\n        if cid not in seen_ids:\n            customer_id_name.append((cid, name))\n            seen_ids.add(cid)\n\n    # For each customer, sum their orders\n    # Need to group by Customer_ID (not Name), as in the SQL ON T1.Customer_ID = T2.Customer_ID\n    # and GROUP BY T1.Name (which is unique per id in this data)\n    id_to_total = {}\n    for customer in data.get(\"customers\", []):\n        cid = customer[\"Customer_ID\"]\n        total = 0\n        for order in customer.get(\"orders\", []):\n            total += order.get(\"Quantity\", 0)\n        id_to_total[cid] = total\n\n    result = []\n    for cid, name in customer_id_name:\n        result.append({\n            \"Name\": name,\n            \"sum(T2.Quantity)\": id_to_total.get(cid, 0)\n        })\n    return result": [
            {
              "Name": "Arthur Morris",
              "sum(T2.Quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(T2.Quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(T2.Quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Sid Barnes",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Bill Edrich",
              "sum(T2.Quantity)": 0
            },
            {
              "Name": "Lindsay Hassett",
              "sum(T2.Quantity)": 0
            }
          ],
          "def transform(data):\n    # Only include customers who have orders (\"customer_order\" table in SQL INNER JOIN means only customers with at least one order)\n    result = []\n    for customer in data.get(\"customers\", []):\n        orders = customer.get(\"orders\", [])\n        if not orders:\n            continue  # INNER JOIN logic: only customers with at least one order\n        total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n        result.append({\"Name\": customer[\"Name\"], \"sum(T2.Quantity)\": total_quantity})\n    return result": [
            {
              "Name": "Arthur Morris",
              "sum(T2.Quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(T2.Quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(T2.Quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(T2.Quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(T2.Quantity)": 1
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "What is the total quantities of dishes ordered by each customer ? List the customer name and the total quantity .",
    "query": "select t1.name ,  sum(t2.quantity) from customer as t1 join customer_order as t2 on t1.customer_id  =  t2.customer_id group by t1.name",
    "query_output": [
      {
        "Name": "Arthur Morris",
        "sum(t2.quantity)": 4
      },
      {
        "Name": "Cyril Washbrook",
        "sum(t2.quantity)": 2
      },
      {
        "Name": "Denis Compton",
        "sum(t2.quantity)": 3
      },
      {
        "Name": "Donald Bradman",
        "sum(t2.quantity)": 1
      },
      {
        "Name": "Len Hutton",
        "sum(t2.quantity)": 1
      }
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map({\n    Name: .Name,\n    \"sum(t2.quantity)\": (\n      (.orders // [])\n      | map(.Quantity)\n      | add // 0\n    )\n})": [
            [
              {
                "Name": "Arthur Morris",
                "sum(t2.quantity)": 4
              },
              {
                "Name": "Denis Compton",
                "sum(t2.quantity)": 3
              },
              {
                "Name": "Donald Bradman",
                "sum(t2.quantity)": 1
              },
              {
                "Name": "Cyril Washbrook",
                "sum(t2.quantity)": 2
              },
              {
                "Name": "Len Hutton",
                "sum(t2.quantity)": 1
              },
              {
                "Name": "Sid Barnes",
                "sum(t2.quantity)": 0
              },
              {
                "Name": "Bill Edrich",
                "sum(t2.quantity)": 0
              },
              {
                "Name": "Lindsay Hassett",
                "sum(t2.quantity)": 0
              }
            ]
          ],
          ".customers\n| map({\n    Name: .Name,\n    \"sum(t2.quantity)\": ((.orders // []) | map(.Quantity) | add // 0)\n})\n| map(select(.\"sum(t2.quantity)\" > 0))": [
            [
              {
                "Name": "Arthur Morris",
                "sum(t2.quantity)": 4
              },
              {
                "Name": "Denis Compton",
                "sum(t2.quantity)": 3
              },
              {
                "Name": "Donald Bradman",
                "sum(t2.quantity)": 1
              },
              {
                "Name": "Cyril Washbrook",
                "sum(t2.quantity)": 2
              },
              {
                "Name": "Len Hutton",
                "sum(t2.quantity)": 1
              }
            ]
          ],
          ".customers\n| map({Name: .Name, \"sum(t2.quantity)\": ((.orders // []) | map(.Quantity) | add // 0)})\n| map(select(.\"sum(t2.quantity)\" > 0))\n| .": [
            [
              {
                "Name": "Arthur Morris",
                "sum(t2.quantity)": 4
              },
              {
                "Name": "Denis Compton",
                "sum(t2.quantity)": 3
              },
              {
                "Name": "Donald Bradman",
                "sum(t2.quantity)": 1
              },
              {
                "Name": "Cyril Washbrook",
                "sum(t2.quantity)": 2
              },
              {
                "Name": "Len Hutton",
                "sum(t2.quantity)": 1
              }
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    result = []\n    for customer in data.get('customers', []):\n        name = customer.get(\"Name\")\n        orders = customer.get(\"orders\", [])\n        total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n        result.append({\"Name\": name, \"sum(t2.quantity)\": total_quantity})\n    return result": [
            {
              "Name": "Arthur Morris",
              "sum(t2.quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(t2.quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(t2.quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Sid Barnes",
              "sum(t2.quantity)": 0
            },
            {
              "Name": "Bill Edrich",
              "sum(t2.quantity)": 0
            },
            {
              "Name": "Lindsay Hassett",
              "sum(t2.quantity)": 0
            }
          ],
          "def transform(data):\n    # Make a mapping from Name to total quantity\n    results = []\n    for customer in data.get('customers', []):\n        name = customer.get(\"Name\")\n        orders = customer.get(\"orders\", [])\n        total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n        results.append((name, total_quantity))\n    # The SQL result is sorted by Name\n    results.sort(key=lambda x: x[0])\n    return [{\"Name\": name, \"sum(t2.quantity)\": qty} for name, qty in results]": [
            {
              "Name": "Arthur Morris",
              "sum(t2.quantity)": 4
            },
            {
              "Name": "Bill Edrich",
              "sum(t2.quantity)": 0
            },
            {
              "Name": "Cyril Washbrook",
              "sum(t2.quantity)": 2
            },
            {
              "Name": "Denis Compton",
              "sum(t2.quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Len Hutton",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Lindsay Hassett",
              "sum(t2.quantity)": 0
            },
            {
              "Name": "Sid Barnes",
              "sum(t2.quantity)": 0
            }
          ],
          "def transform(data):\n    results = []\n    for customer in data.get('customers', []):\n        name = customer.get(\"Name\")\n        orders = customer.get(\"orders\", [])\n        # Only include customers with at least one order (mimics the SQL inner join)\n        if orders and len(orders) > 0:\n            total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n            results.append({\"Name\": name, \"sum(t2.quantity)\": total_quantity})\n    return results": [
            {
              "Name": "Arthur Morris",
              "sum(t2.quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(t2.quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(t2.quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(t2.quantity)": 1
            }
          ],
          "def transform(data):\n    results = []\n    for customer in data.get('customers', []):\n        name = customer.get(\"Name\")\n        orders = customer.get(\"orders\", [])\n        if orders and len(orders) > 0:\n            total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n            results.append({\"Name\": name, \"sum(t2.quantity)\": total_quantity})\n    # For exact SQL-like behavior, order by the first order's insertion order for stable output if necessary\n    return results": [
            {
              "Name": "Arthur Morris",
              "sum(t2.quantity)": 4
            },
            {
              "Name": "Denis Compton",
              "sum(t2.quantity)": 3
            },
            {
              "Name": "Donald Bradman",
              "sum(t2.quantity)": 1
            },
            {
              "Name": "Cyril Washbrook",
              "sum(t2.quantity)": 2
            },
            {
              "Name": "Len Hutton",
              "sum(t2.quantity)": 1
            }
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show the customers with total quantity of order bigger than 1.",
    "query": "SELECT T1.Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID GROUP BY T1.Name HAVING sum(T2.Quantity)  >  1",
    "query_output": [
      "Arthur Morris",
      "Cyril Washbrook",
      "Denis Compton"
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map(select(.orders != null and (.orders | map(.Quantity) | add // 0) > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Cyril Washbrook"
            ]
          ],
          ".customers\n| map(select((.orders // []) | map(.Quantity) | add > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Cyril Washbrook"
            ]
          ],
          ".customers\n| map(select(((.orders // []) | map(.Quantity) | add) > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Cyril Washbrook"
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        total_quantity = 0\n        for order in customer.get(\"orders\", []):\n            total_quantity += order.get(\"Quantity\", 0)\n        if total_quantity > 1:\n            result.append(customer.get(\"Name\"))\n    return result": [
            "Arthur Morris",
            "Denis Compton",
            "Cyril Washbrook"
          ],
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        # \"Sum of quantity of all orders for a customer\" (must only include customers with at least one order)\n        orders = customer.get(\"orders\", [])\n        if not orders:\n            continue\n        total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n        # Now the GROUP BY/HAVING: only if sum > 1\n        if total_quantity > 1:\n            result.append(customer[\"Name\"])\n    return result": [
            "Arthur Morris",
            "Denis Compton",
            "Cyril Washbrook"
          ],
          "def transform(data):\n    # The SQL joins customer to customer_order, GROUP BY customer.Name, HAVING sum(T2.Quantity) > 1.\n    # All customers with total quantity > 1, but only those participated in at least one 'order'\n    # Note: Only those names which appear in customer_order (i.e., have at least one order) should be included.\n    # Make sure to only sum Quantities where there are at least some orders (at least one orders entry).\n    result = []\n    for customer in data.get(\"customers\", []):\n        orders = customer.get(\"orders\")\n        if orders and len(orders) > 0:\n            total_quantity = sum(order.get(\"Quantity\", 0) for order in orders)\n            # The difference is: The expected output's second name is \"Cyril Washbrook\" (not \"Denis Compton\")\n            # It suggests there is something about counting: maybe only customers who have orders? That's handled\n            if total_quantity > 1:\n                result.append(customer['Name'])\n    return result": [
            "Arthur Morris",
            "Denis Compton",
            "Cyril Washbrook"
          ],
          "def transform(data):\n    # The expected output differs from previous results, so let's try to directly map the SQL logic:\n    # Join: every customer is joined to their orders.\n    # GROUP BY T1.Name, HAVING sum(T2.Quantity) > 1\n    # If there are duplicate customer names, group by name (not Customer_ID).\n    # So: sum all quantities per customer name, regardless of Customer_ID\n  \n    from collections import defaultdict\n\n    name_quantity = defaultdict(int)\n    for customer in data.get(\"customers\", []):\n        name = customer.get(\"Name\")\n        orders = customer.get(\"orders\", [])\n        for order in orders:\n            name_quantity[name] += order.get(\"Quantity\", 0)\n    result = []\n    for name, qty in name_quantity.items():\n        if qty > 1:\n            result.append(name)\n    return result": [
            "Arthur Morris",
            "Denis Compton",
            "Cyril Washbrook"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Which customers have total order quantity greater than 1? Give me the customer names.",
    "query": "SELECT T1.Name FROM customer AS T1 JOIN customer_order AS T2 ON T1.Customer_ID  =  T2.Customer_ID GROUP BY T1.Name HAVING sum(T2.Quantity)  >  1",
    "query_output": [
      "Arthur Morris",
      "Cyril Washbrook",
      "Denis Compton"
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          ".customers\n| map({Name, total_quantity: (if (.orders // []) | length > 0 then (.orders | map(.Quantity) | add) else 0 end)})\n| map(select(.total_quantity > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Cyril Washbrook"
            ]
          ],
          ".customers\n| map(select((.orders // []) | map(.Quantity) | add > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Denis Compton",
              "Cyril Washbrook"
            ]
          ],
          ".customers\n| map({Name, total_quantity: ((.orders // []) | map(.Quantity) | add)})\n| group_by(.Name)\n| map({Name: .[0].Name, total_quantity: (map(.total_quantity) | add)})\n| map(select(.total_quantity > 1))\n| map(.Name)": [
            [
              "Arthur Morris",
              "Cyril Washbrook",
              "Denis Compton"
            ]
          ]
        }
      },
      "python": {
        "kind": "success",
        "python": [
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        total_quantity = 0\n        # the SQL GROUPs by name, but the schema has name unique per customer\n        for order in customer.get(\"orders\", []):\n            total_quantity += order.get(\"Quantity\", 0)\n        # Only include customer if they have at least one order, and quantity sum > 1\n        if total_quantity > 1:\n            result.append(customer[\"Name\"])\n    # The SQL query would only return each customer once, in name order from underlying table\n    # Let's sort the output alphabetically, as SQL does not specify ordering but sample likely expects it\n    return sorted(result)"
        ],
        "candidates": {
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        total_quantity = 0\n        for order in customer.get(\"orders\", []):\n            total_quantity += order.get(\"Quantity\", 0)\n        if total_quantity > 1:\n            result.append(customer.get(\"Name\"))\n    return result": [
            "Arthur Morris",
            "Denis Compton",
            "Cyril Washbrook"
          ],
          "def transform(data):\n    result = []\n    for customer in data.get(\"customers\", []):\n        total_quantity = 0\n        # the SQL GROUPs by name, but the schema has name unique per customer\n        for order in customer.get(\"orders\", []):\n            total_quantity += order.get(\"Quantity\", 0)\n        # Only include customer if they have at least one order, and quantity sum > 1\n        if total_quantity > 1:\n            result.append(customer[\"Name\"])\n    # The SQL query would only return each customer once, in name order from underlying table\n    # Let's sort the output alphabetically, as SQL does not specify ordering but sample likely expects it\n    return sorted(result)": [
            "Arthur Morris",
            "Cyril Washbrook",
            "Denis Compton"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Show distinct managers of branches.",
    "query": "SELECT DISTINCT Manager FROM branch",
    "query_output": [
      "Ashby Lazale",
      "Breton Robert",
      "Campbell Jessie",
      "Cobb Sedrick",
      "Hayes Steven",
      "Komisarjevsky Joshua",
      "Peeler Russell",
      "Reynolds Richard",
      "Rizzo Todd",
      "Webb Daniel"
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          "[\n  .customers[]\n  | ( .orders // [] )\n  | .[]\n  | .branch.Manager\n]\n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[\n  .customers[]\n  | ( .orders // [] )\n  | map(.branch.Manager)\n]\n| add\n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[\n  .customers[]\n  | ( .orders // [] )\n  | map(.branch.Manager)\n] \n| flatten \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    managers = set()\n    customers = data.get(\"customers\", [])\n    for customer in customers:\n        for order in customer.get(\"orders\", []):\n            branch = order.get(\"branch\")\n            if branch and \"Manager\" in branch:\n                managers.add(branch[\"Manager\"])\n    return list(managers)": [
            "Rizzo Todd",
            "Webb Daniel",
            "Komisarjevsky Joshua"
          ],
          "def transform(data):\n    managers = []\n    seen = set()\n    customers = data.get(\"customers\", [])\n    for customer in customers:\n        for order in customer.get(\"orders\", []):\n            branch = order.get(\"branch\")\n            if branch and \"Manager\" in branch:\n                manager = branch[\"Manager\"]\n                if manager not in seen:\n                    managers.append(manager)\n                    seen.add(manager)\n    return managers": [
            "Webb Daniel",
            "Rizzo Todd",
            "Komisarjevsky Joshua"
          ],
          "def transform(data):\n    # To get the managers in the same order as the first appearance of their branches (by Branch_ID)\n    seen_branch = set()\n    branch_managers = []\n    customers = data.get(\"customers\", [])\n    for customer in customers:\n        for order in customer.get(\"orders\", []):\n            branch = order.get(\"branch\")\n            if branch:\n                branch_id = branch.get(\"Branch_ID\")\n                manager = branch.get(\"Manager\")\n                if branch_id is not None and branch_id not in seen_branch and manager is not None:\n                    seen_branch.add(branch_id)\n                    branch_managers.append(manager)\n    return branch_managers": [
            "Webb Daniel",
            "Rizzo Todd",
            "Komisarjevsky Joshua"
          ],
          "def transform(data):\n    # Collect all unique branches by Branch_ID, picking the first encountered for order\n    branch_id_to_manager = {}\n    customers = data.get(\"customers\", [])\n    for customer in customers:\n        for order in customer.get(\"orders\", []):\n            branch = order.get(\"branch\")\n            if branch:\n                branch_id = branch.get(\"Branch_ID\")\n                manager = branch.get(\"Manager\")\n                if branch_id is not None and manager is not None:\n                    if branch_id not in branch_id_to_manager:\n                        branch_id_to_manager[branch_id] = manager\n    # Now sort by Branch_ID to match the expected order (lowest Branch_ID first, as in SQL DISTINCT)\n    # but most likely the expected output wants order by manager name\n    # Let's try sorting by manager name lexicographically (as would SELECT DISTINCT do if not sorted by ID)\n    managers = list(branch_id_to_manager.values())\n    managers = sorted(set(managers))\n    return managers": [
            "Komisarjevsky Joshua",
            "Rizzo Todd",
            "Webb Daniel"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Who are the distinct managers of branches?",
    "query": "SELECT DISTINCT Manager FROM branch",
    "query_output": [
      "Ashby Lazale",
      "Breton Robert",
      "Campbell Jessie",
      "Cobb Sedrick",
      "Hayes Steven",
      "Komisarjevsky Joshua",
      "Peeler Russell",
      "Reynolds Richard",
      "Rizzo Todd",
      "Webb Daniel"
    ],
    "converted": {
      "jq": {
        "kind": "failure",
        "jq": [],
        "candidates": {
          "[\n  .customers[]\n  | .orders? // []\n  | .[]\n  | .branch.Manager\n] \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[\n  .customers[]\n  | .orders? // []\n  | map(.branch.Manager)\n  | .[]\n] \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[\n  .customers[]\n  | .orders? // []\n  | map(.branch.Manager)\n] \n| flatten \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          ".customers[]\n| .orders? // []\n| map(.branch.Manager)\n| unique\n| .[]": [
            "Webb Daniel",
            "Rizzo Todd",
            "Webb Daniel",
            "Webb Daniel",
            "Komisarjevsky Joshua",
            "Komisarjevsky Joshua"
          ],
          ".customers[]\n| .orders? // []\n| map(.branch.Manager)\n| .[]": [
            "Webb Daniel",
            "Webb Daniel",
            "Rizzo Todd",
            "Webb Daniel",
            "Komisarjevsky Joshua",
            "Komisarjevsky Joshua"
          ],
          "[.customers[] | .orders? // [] | .[] | .branch.Manager] \n| unique\n| .[]": [
            "Komisarjevsky Joshua",
            "Rizzo Todd",
            "Webb Daniel"
          ],
          "[.customers[] | .orders? // [] | map(.branch.Manager) | .[]] \n| unique\n| .[]": [
            "Komisarjevsky Joshua",
            "Rizzo Todd",
            "Webb Daniel"
          ],
          "[ .customers[] | (.orders? // [])[] | .branch ] \n| unique_by(.Manager) \n| map(.Manager)": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[ .customers[] | (.orders? // [])[] | .branch.Manager ] \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[.customers[] | (.orders? // [])[] | .branch | {Manager, Branch_ID}]\n| unique\n| map(.Manager)\n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ],
          "[.customers[] | (.orders? // [])[] | .branch | [.Manager, .Branch_ID]] \n| unique \n| map(.[0]) \n| unique": [
            [
              "Komisarjevsky Joshua",
              "Rizzo Todd",
              "Webb Daniel"
            ]
          ]
        }
      },
      "python": {
        "kind": "failure",
        "python": [],
        "candidates": {
          "def transform(data):\n    managers = set()\n    # Check all customers\n    for customer in data.get('customers', []):\n        # Check all orders for this customer\n        for order in customer.get('orders', []):\n            branch = order.get('branch')\n            if branch and 'Manager' in branch:\n                managers.add(branch['Manager'])\n    return list(managers)": [
            "Rizzo Todd",
            "Webb Daniel",
            "Komisarjevsky Joshua"
          ],
          "def transform(data):\n    managers = set()\n    # We want all distinct managers of branches, so we must aggregate all unique branches by Branch_ID, then fetch their Manager.\n    branch_id_to_manager = {}\n    for customer in data.get('customers', []):\n        for order in customer.get('orders', []):\n            branch = order.get('branch')\n            if branch:\n                branch_id = branch.get('Branch_ID')\n                manager = branch.get('Manager')\n                if branch_id is not None and manager is not None:\n                    # Always store the manager for this branch id (shouldn't change for same branch)\n                    branch_id_to_manager[branch_id] = manager\n    # Return the list of managers (distinct, sorted for consistency)\n    return sorted(set(branch_id_to_manager.values()))": [
            "Komisarjevsky Joshua",
            "Rizzo Todd",
            "Webb Daniel"
          ],
          "def transform(data):\n    # To get the DISTINCT managers of branches as in SELECT DISTINCT Manager FROM branch,\n    # we need to get every possible manager from every branch object in any order -> branch\n    managers = set()\n    for customer in data.get('customers', []):\n        for order in customer.get('orders', []):\n            branch = order.get('branch')\n            if branch and 'Manager' in branch:\n                managers.add(branch['Manager'])\n    # The expected output suggests the managers should be in the order of first appearance\n    # So we iterate again in input order, collecting unique ones in that order\n    result = []\n    seen = set()\n    for customer in data.get('customers', []):\n        for order in customer.get('orders', []):\n            branch = order.get('branch')\n            if branch and 'Manager' in branch:\n                manager = branch['Manager']\n                if manager not in seen:\n                    result.append(manager)\n                    seen.add(manager)\n    return result": [
            "Webb Daniel",
            "Rizzo Todd",
            "Komisarjevsky Joshua"
          ],
          "def transform(data):\n    # We want all distinct Manager names as per the \"branch\" table\n    # Each \"branch\" is an object inside an order's \"branch\", but possibly duplicated\n    # To avoid duplicates, we'll use a dict to store branches by (Branch_ID)\n    branch_ids_seen = set()\n    managers_in_order = []\n    for customer in data.get('customers', []):\n        for order in customer.get('orders', []):\n            branch = order.get('branch')\n            if branch:\n                branch_id = branch.get('Branch_ID')\n                manager = branch.get('Manager')\n                if branch_id is not None and manager is not None:\n                    if branch_id not in branch_ids_seen:\n                        managers_in_order.append(manager)\n                        branch_ids_seen.add(branch_id)\n    return managers_in_order": [
            "Webb Daniel",
            "Rizzo Todd",
            "Komisarjevsky Joshua"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "List the names of customers that do not have any order.",
    "query": "SELECT name FROM customer WHERE Customer_ID NOT IN (SELECT Customer_ID FROM customer_order)",
    "query_output": [
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett"
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | map(select(.orders | length == 0) | .Name)[]",
          "[.customers[] | select(.orders | length == 0) | .Name] | .[]"
        ],
        "candidates": {
          ".customers | map(select(.orders | length == 0) | .Name)": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select((.orders | length) == 0) | .Name)": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select(.orders | length == 0) | .Name) | .": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          "[.customers[] | select(.orders | length == 0) | .Name]": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select(.orders | length == 0) | .Name) | flatten": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select(.orders | length == 0) | .Name)[]": [
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett"
          ],
          "[.customers[] | select(.orders | length == 0) | .Name] | .[]": [
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett"
          ]
        }
      }
    }
  },
  {
    "db_id": "restaurant_bills",
    "question": "Which customers do not have any order? Give me the customer names.",
    "query": "SELECT name FROM customer WHERE Customer_ID NOT IN (SELECT Customer_ID FROM customer_order)",
    "query_output": [
      "Sid Barnes",
      "Bill Edrich",
      "Lindsay Hassett"
    ],
    "converted": {
      "jq": {
        "kind": "success",
        "jq": [
          ".customers | map(select((.orders | length) == 0) | .Name)[]"
        ],
        "candidates": {
          ".customers | map(select((.orders | length) == 0) | .Name)": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select((.orders | length) == 0) | .Name) | flatten": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ],
          ".customers | map(select((.orders | length) == 0) | .Name)[]": [
            "Sid Barnes",
            "Bill Edrich",
            "Lindsay Hassett"
          ],
          "[ .customers[] | select((.orders | length) == 0) | .Name ]": [
            [
              "Sid Barnes",
              "Bill Edrich",
              "Lindsay Hassett"
            ]
          ]
        }
      }
    }
  }
]