Aggregate Expressions
Introduction
Aggregate expression types allow you to summarize and calculate collective properties of your data. These expressions enable you to define how to aggregate over different data types, facilitating efficient data manipulation and retrieval.
Aggregate expressions can be used to configure how data is summarized in your models, or as the types of arguments to commands or models.
How AggregateExpressions work
Lifecycle
Below this description of the lifecycle are examples for each step and how to define AggregateExpressions in your metadata files.
You'll need to ensure you've generated ScalarTypes and DataConnectorScalarRepresentations for the data types you want to aggregate over. We recommend saving these in your connector's type definition file.
Once you have these, you can create AggregateExpression objects for the types you want to aggregate over. We recommend these be saved in a model's metadata file.
Finally, you'll need to update your graphql-config.hml
in the globals
subgraph to
include an aggregate
field in the definition
.
Once these are included, you'll need to create a new build using the CLI.
Examples
In the following example, we'll show the snippets necessary to implement the example explained above: an
AggregateExpression for the Reviews
model of our sample application.
# Existing definitions above
---
kind: ScalarType
version: v1
definition:
name: Numeric
graphql:
typeName: Numeric
---
kind: DataConnectorScalarRepresentation
version: v1
definition:
dataConnectorName: my_connector
dataConnectorScalarType: numeric
representation: Numeric
graphql:
comparisonExpressionTypeName: NumericComparisonExp
# Existing objects above
---
kind: AggregateExpression
version: v1
definition:
name: Int4_aggregate_exp
operand:
scalar:
aggregatedType: Int4
aggregationFunctions:
- name: avg
returnType: Numeric
dataConnectorAggregationFunctionMapping:
- dataConnectorName: my_connector
dataConnectorScalarType: int4
functionMapping:
avg:
name: avg
graphql:
selectTypeName: Int4_aggregate_fields
---
kind: AggregateExpression
version: v1
definition:
name: Reviews_aggregate_exp
operand:
object:
aggregatedType: Reviews
aggregatableFields:
- fieldName: rating
aggregateExpression: Int4_aggregate_exp
graphql:
selectTypeName: Reviews_aggregate_fields
description: Aggregate over Reviews
kind: GraphqlConfig
version: v1
definition:
query:
rootOperationTypeName: Query
argumentsInput:
fieldName: args
limitInput:
fieldName: limit
offsetInput:
fieldName: offset
filterInput:
fieldName: where
operatorNames:
and: _and
or: _or
not: _not
isNull: _is_null
orderByInput:
fieldName: order_by
enumDirectionValues:
asc: Asc
desc: Desc
enumTypeNames:
- directions:
- Asc
- Desc
typeName: OrderBy
aggregate:
filterInputFieldName: filter_input
countFieldName: _count
countDistinctFieldName: _count_distinct
mutation:
rootOperationTypeName: Mutation
Metadata structure
AggregateExpression
Definition of an aggregate expression on an OpenDD type.
Key | Value | Required | Description |
---|---|---|---|
kind | AggregateExpression | true | |
version | v1 | true | |
definition | AggregateExpressionV1 | true | Definition of how to aggregate over a particular operand type |
Example:
kind: AggregateExpression
version: v1
definition:
name: Invoice_aggregate_exp
operand:
object:
aggregatedType: Invoice
aggregatableFields:
- fieldName: Total
aggregateExpression: Float_aggregate_exp
graphql:
selectTypeName: Invoice_aggregate_fields
description: Aggregate over Invoices
AggregateExpressionV1
Definition of how to aggregate over a particular operand type
Key | Value | Required | Description |
---|---|---|---|
name | AggregateExpressionName | true | The name of the aggregate expression. |
operand | AggregateOperand | true | The type this aggregation expression aggregates over, and its associated configuration |
count | AggregateCountDefinition / null | false | Configuration for the count aggregate function used over the operand |
countDistinct | AggregateCountDefinition / null | false | Configuration for the count distinct aggregate function used over the operand |
graphql | AggregateExpressionGraphQlDefinition / null | false | Configuration for how this command should appear in the GraphQL schema. |
description | string / null | false | The description of the aggregate expression. Gets added to the description of the command's root field in the GraphQL schema. |
AggregateExpressionGraphQlDefinition
The definition of how an aggregate expression should appear in the GraphQL API.
Key | Value | Required | Description |
---|---|---|---|
selectTypeName | GraphQlTypeName | true | The type name to use for the aggregate selection type |
deprecated | Deprecated / null | false | Whether this command root field is deprecated. If set, this will be added to the graphql schema as a deprecated field. |
Example:
selectTypeName: Invoice_aggregate_fields
Deprecated
OpenDd configuration to indicate whether an object type field, relationship, model root field or command root field is deprecated.
Key | Value | Required | Description |
---|---|---|---|
reason | string / null | false | The reason for deprecation. |
GraphQlTypeName
The name of a GraphQL type.
Value: string
AggregateCountDefinition
Definition of a count aggregation function
Key | Value | Required | Description |
---|---|---|---|
enable | boolean | true | Whether or not the aggregate function is available for use or not |
description | string / null | false | A description of the aggregation function. Gets added to the description of the field in the GraphQL schema. |
returnType | TypeName / null | false | The scalar type that the count aggregation function returns. Must be an integer type. If omitted, Int is used as the default. |
AggregateOperand
Definition of an aggregate expression's operand
Must have exactly one of the following fields:
Key | Value | Required | Description |
---|---|---|---|
object | ObjectAggregateOperand | false | Definition of an aggregate over an object-typed operand |
scalar | ScalarAggregateOperand | false | Definition of an aggregate over a scalar-typed operand |
ScalarAggregateOperand
Definition of an aggregate over a scalar-typed operand
Key | Value | Required | Description |
---|---|---|---|
aggregatedType | TypeName | true | The name of the scalar type the aggregate expression is aggregating |
aggregationFunctions | [AggregationFunctionDefinition] | true | The aggregation functions that operate over the scalar type |
dataConnectorAggregationFunctionMapping | [DataConnectorAggregationFunctionMapping] | true | Mapping of aggregation functions to corresponding aggregation functions in various data connectors |
DataConnectorAggregationFunctionMapping
Definition of how to map an aggregate expression's aggregation functions to data connector aggregation functions.
Key | Value | Required | Description |
---|---|---|---|
dataConnectorName | DataConnectorName | true | The data connector being mapped to |
dataConnectorScalarType | DataConnectorScalarType | true | The matching scalar type in the data connector for the operand scalar type |
functionMapping | AggregationFunctionMappings | true | Mapping from Open DD aggregation function to data connector aggregation function |
AggregationFunctionMappings
Mapping of aggregation functions to their matching aggregation functions in the data connector.
Key | Value | Required | Description |
---|---|---|---|
<customKey> | AggregateFunctionMapping | false | Definition of how to map the aggregation function to a function in the data connector |
AggregateFunctionMapping
Definition of how to map the aggregation function to a function in the data connector
Key | Value | Required | Description |
---|---|---|---|
name | DataConnectorAggregationFunctionName | true | The name of the aggregation function in the data connector |
DataConnectorAggregationFunctionName
The name of an aggregation function in a data connector
Value: string
DataConnectorScalarType
The name of a scalar type in a data connector.
Value: string
DataConnectorName
The name of a data connector.
Value: string
AggregationFunctionDefinition
Definition of an aggregation function
Key | Value | Required | Description |
---|---|---|---|
name | AggregationFunctionName | true | The name of the aggregation function |
description | string / null | false | A description of the aggregation function. Gets added to the description of the field in the GraphQL schema. |
returnType | TypeReference | true |
TypeReference
A reference to an Open DD type including nullable values and arrays. Suffix '!' to indicate a non-nullable reference, and wrap in '[]' to indicate an array. Eg: '[String!]!' is a non-nullable array of non-nullable strings.
Value: string
AggregationFunctionName
The name of an aggregation function.
Value: string
TypeName
The name of the scalar type the aggregate expression is aggregating
One of the following values:
Value | Description |
---|---|
InbuiltType | An inbuilt primitive OpenDD type. |
CustomTypeName |
InbuiltType
An inbuilt primitive OpenDD type.
Value: ID
/ Int
/ Float
/ Boolean
/ String
ObjectAggregateOperand
Definition of an aggregate over an object-typed operand
Key | Value | Required | Description |
---|---|---|---|
aggregatedType | CustomTypeName | true | The name of the object type the aggregate expression is aggregating |
aggregatableFields | [AggregatableFieldDefinition] | true | The fields on the object that are aggregatable |
AggregatableFieldDefinition
Definition of an aggregatable field on an object type
Key | Value | Required | Description |
---|---|---|---|
fieldName | FieldName | true | The name of the field on the operand aggregated type that is aggregatable |
description | string / null | false | A description of the aggregatable field. Gets added to the description of the field in the GraphQL schema. |
aggregateExpression | AggregateExpressionName | true | The aggregate expression used to aggregate the type of the field |
FieldName
The name of a field in a user-defined object type.
Value: string
CustomTypeName
The name of a user-defined type.
Value: string
AggregateExpressionName
The name of an aggregate expression.
Value: string