The arguments supported are ids
, where
, orderBy
, skip
, and take
.
Arguments are executed in that order.
Queries entities by id. Currently the only supported identity member (property or field) name is Id
.
String, Guid, Double, Boolean, Float, Byte, DateTime, DateTimeOffset, Decimal, Int16, Int32, Int64, UInt16, UInt32, and UInt64.
{
entities (ids: "1")
{
property
}
}
{
entities (ids: ["1", "2"])
{
property
}
}
Where statements are and'ed together and executed in order.
All where statements require a path
. This is a full path to a, possible nested, property. Eg a property at the root level could be Address
, while a nested property could be Address.Street
. No null checking of nested values is done.
String, Guid, Double, Boolean, Float, Byte, DateTime, DateOnly, TimeOnly, DateTimeOffset, Decimal, Int16, Int32, Int64, UInt16, UInt32, UInt64, and Enum.
{
timeEntities (where: {path: 'Property', comparison: equal, value: '10:11 AM'})
{
id
}
}
{
dateEntities (where: {path: 'Property', comparison: equal, value: '2020-10-1'})
{
id
}
}
equal
: (the default value ifcomparison
is omitted)greaterThan
greaterThanOrEqual
lessThan
lessThanOrEqual
:contains
: Only works withstring
startsWith
: Only works withstring
endsWith
: Only works withstring
in
: Check if a member existing in a given collection of valuesnotIn
: Negation of in operator (Deprecated, usenegate
property within
operator instead)like
: Performs a SQL Like by usingEF.Functions.Like
Case of comparison names are ignored. So, for example, EndsWith
, endsWith
, and endswith
are allowed.
Single where statements can be expressed:
{
entities
(where: {
path: "Property",
comparison: "equal",
value: "the value"})
{
property
}
}
{
testEntities
(where: {
path: "Property",
comparison: "in",
value: ["Value1", "Value2"]})
{
property
}
}
Expressions in the same logical grouping can be expressed together with a connector, on the preceeding where expression:
and
: (default if no connector provided)or
When trying to logically group expressions, provide a Where expression with only the groupedExpressions
property.
Multiple where statements with a logical grouping can be expressed:
{
entities
(where:
[
{path: "Property", comparison: "startsWith", value: "Valu"},
{
groupedExpressions: [
{path: "Property", comparison: "endsWith", value: "ue", connector: "or"},
{path: "Property", comparison: "endsWith", value: "id"}
]
}
]
)
{
property
}
}
The above expression written as a logical statement would be:
Property.startsWith("value") && (Property.endsWith("ue") || Property.endsWith("id"))
To negate any expression, including groupedExpressions
, provide the negate
property with true (Default is false).
Example:
{
entities
(where:
[
{path: "Property", comparison: "startsWith", value: "Valu", negate: true},
{
negate: true,
groupedExpressions: [
{path: "Property", comparison: "endsWith", value: "ue", connector: "or"},
{path: "Property", comparison: "endsWith", value: "id"}
]
}
]
)
{
property
}
}
A common query function is constraining a master set by some property of the detail list. For example to filter all orders by line items for a specific product.
Note: This only constrains the master list and doesn't affect the detail list, re-query the detail list with the same query to achieve this effect.
To query a list member graph property, use parenthesis ([]
) to wrap the property. Example:
{
entities
(where:
[
{
path: "ListProperty[Property]",
comparison: "startsWith",
value: "Valu"
}
]
)
{
property
}
}
Or:
{
entities
(where:
[
{
path: "ListProperty[Property.AnotherProperty]",
comparison: "startsWith",
value: "Valu"
}
]
)
{
property
}
}
All string comparisons are, by default, done using no StringComparison. A custom StringComparison can be used via the case
attribute.
{
entities
(where: {
path: "Property",
comparison: "endsWith",
value: "the value",
case: "Ordinal"})
{
property
}
}
Null can be expressed by omitting the value
:
{
entities
(where: {path: "Property", comparison: "equal"})
{
property
}
}
{
entities (orderBy: {path: "Property"})
{
property
}
}
{
entities (orderBy: {path: "Property", descending: true})
{
property
}
}
Queryable.Take or Enumerable.Take can be used as follows:
{
entities (take: 1)
{
property
}
}
Queryable.Skip or Enumerable.Skip can be used as follows:
{
entities (skip: 1)
{
property
}
}