Concept Flow - Field selection
Start Query
Parse Query Fields
Fetch Data for Each Field
Assemble Response Object
Return Selected Fields Only
GraphQL reads the query, fetches only the requested fields, and returns them in the response.
query {
user {
id
name
}
}| Step | Action | Field Processed | Data Fetched | Response State |
|---|---|---|---|---|
| 1 | Parse query | user | N/A | {} |
| 2 | Fetch field | id | 123 | {"user": {"id": 123}} |
| 3 | Fetch field | name | Alice | {"user": {"id": 123, "name": "Alice"}} |
| 4 | Assemble response | all fields | N/A | {"user": {"id": 123, "name": "Alice"}} |
| 5 | Return response | N/A | N/A | {"user": {"id": 123, "name": "Alice"}} |
| Variable | Start | After Step 2 | After Step 3 | Final |
|---|---|---|---|---|
| response | {} | {"user": {"id": 123}} | {"user": {"id": 123, "name": "Alice"}} | {"user": {"id": 123, "name": "Alice"}} |
GraphQL Field Selection:
- Query specifies exactly which fields to fetch.
- Server fetches only requested fields.
- Response includes only those fields.
- Saves bandwidth and improves efficiency.
- Example: query { user { id name } } returns only id and name.