Documentation Index
Fetch the complete documentation index at: https://docs.helix-db.com/llms.txt
Use this file to discover all available pages before exploring further.
HelixQL is deprecated in HelixDB v2. Queries are now written with the Rust DSL and dispatched as JSON — see the Querying guide. This section is kept as a reference for legacy HelixQL projects.
For the complete documentation index optimized for AI agents, see llms.txt.
HelixQL queries end with a RETURN clause. You can return bindings (variables),
projected properties, aggregations, literals, or choose to return nothing at all.
Quick reference
| Return Type | Syntax | Return Type | Syntax |
|---|
| Return a binding | RETURN users | Exclude fields | RETURN users::!{ email } |
| Return multiple | RETURN user, posts | Aggregation/scalar | RETURN count |
| Project fields | RETURN users::{ name, age } | Literal | RETURN "ok" |
| Only IDs | RETURN users::ID | No payload | RETURN NONE |
When using the Python SDK, the output values are wrapped in an array for multiple query calls, so you will need to access the first element of the array to get the result of the first call.
Returning bindings
Return any previously bound value from your traversal.
QUERY GetAllUsers() =>
users <- N<User>
RETURN users
Returning multiple values creates multiple top-level fields in the response, named
after the variables.
QUERY GetUserAndPosts(user_id: ID) =>
user <- N<User>(user_id)
posts <- user::Out<User_to_Post>
RETURN user, posts
Returning projections and properties
Use property projection to shape the returned data.
QUERY FindUsers() =>
users <- N<User>::RANGE(0, 10)
RETURN users::{ name, age }
Return just the ID of each element:
QUERY FindUserIDs() =>
users <- N<User>::RANGE(0, 10)
RETURN users::ID
Exclude specific properties:
QUERY FindUsersNoPII() =>
users <- N<User>::RANGE(0, 10)
RETURN users::!{ email, location }
You can also create nested or remapped shapes in RETURN using nested mappings:
QUERY FindFriends(user_id: ID) =>
user <- N<User>(user_id)
posts <- user::Out<User_to_Post>::RANGE(0, 20)
RETURN user::|u|{
userID: u::ID,
posts: posts::{
postID: ID,
creatorID: u::ID,
..
}
}
See property access, remappings, and exclusion for more details.
Returning scalars and literals
Aggregations and scalar bindings can be returned directly:
QUERY CountUsers() =>
user_count <- N<User>::COUNT
RETURN user_count
You can also return literals (strings, numbers, booleans) when useful:
QUERY DeleteCity(city_id: ID) =>
DROP N<City>(city_id)
RETURN "success"
Returning nothing
For mutations or maintenance operations where you do not want a response payload,
use RETURN NONE.
QUERY DeleteCityQuietly(city_id: ID) =>
DROP N<City>(city_id)
RETURN NONE
RETURN NONE signals that the query intentionally produces no output values. This is
handy to avoid sending placeholder strings like “success” when a silent acknowledgement
is preferred.