Requirements for CLR user-defined aggregates
Applies to: SQL Server
A type in a common language runtime (CLR) assembly can be registered as a user-defined aggregate function, as long as it implements the required aggregation contract. This contract consists of the SqlUserDefinedAggregate
attribute and the aggregation contract methods. The aggregation contract includes the mechanism to save the intermediate state of the aggregation, and the mechanism to accumulate new values, which consist of four methods: Init
, Accumulate
, Merge
, and Terminate
. Once you meet these requirements, you can take full advantage of user-defined aggregates in SQL Server. This article provides more information about how to create and work with user-defined aggregates. For an example, see Invoke CLR user-defined aggregate functions.
For more information, see SqlUserDefinedAggregateAttribute.
Aggregation methods
The class registered as a user-defined aggregate should support the following instance methods. The query processor uses the following methods to compute the aggregation.
Init method
Syntax:
public void Init();
The query processor uses this method to initialize the computation of the aggregation. This method is invoked once for each group that the query processor is aggregating. The query processor might choose to reuse the same instance of the aggregate class for computing aggregates of multiple groups. The Init
method should perform any clean-up as necessary from previous uses of this instance, and enable it to restart a new aggregate computation.
Accumulate method
Syntax:
public void Accumulate(input-type value[, input-type value, ...]);
One or more parameters representing the parameters of the function. input_type should be the managed SQL Server data type equivalent to the native SQL Server data type specified by input_sqltype in the CREATE AGGREGATE
statement. For more information, see Map CLR parameter data.
For user-defined types (UDTs), the input-type is the same as the UDT type. The query processor uses this method to accumulate the aggregate values. This is invoked once for each value in the group that is being aggregated. The query processor always calls this only after calling the Init
method on the given instance of the aggregate-class. The implementation of this method should update the state of the instance to reflect the accumulation of the argument value being passed in.
Merge method
Syntax:
public void Merge(udagg_class value);
This method can be used to merge another instance of this aggregate class with the current instance. The query processor uses this method to merge multiple partial computations of an aggregation.
Terminate method
Syntax:
public return_type Terminate();
This method completes the aggregate computation and returns the result of the aggregation. The return_type should be a managed SQL Server data type that is the managed equivalent of return_sqltype specified in the CREATE AGGREGATE
statement. The return_type can also be a user-defined type.