GroupAggregator Class |
Namespace: Tangosol.Util.Aggregator
public class GroupAggregator : IEntryAggregator, IPortableObject
The GroupAggregator type exposes the following members.
Name | Description | |
---|---|---|
![]() | GroupAggregator |
Default constructor.
|
![]() | GroupAggregator(IValueExtractor, IEntryAggregator, IFilter) |
Construct a GroupAggregator based on a specified
IValueExtractor and underlying
IEntryAggregator.
|
Name | Description | |
---|---|---|
![]() | Aggregator |
Obtain the underlying IEntryAggregator.
|
![]() | Extractor |
Obtain the underlying IValueExtractor.
|
Name | Description | |
---|---|---|
![]() | Aggregate |
Process a collection of IInvocableCacheEntry
objects using the underlying extractor to split the entries
into non-intersecting (distinct) groups and then apply the
underlying aggregator separately to each group.
|
![]() ![]() | CreateInstance(String, IEntryAggregator) |
Create an instance of GroupAggregator based on a specified member
name(s) and an IEntryAggregator.
|
![]() ![]() | CreateInstance(IValueExtractor, IEntryAggregator) |
Create an instance of GroupAggregator based on a specified
extractor and an IEntryAggregator.
|
![]() ![]() | CreateInstance(String, IEntryAggregator, IFilter) |
Create an instance of GroupAggregator based on a specified member
name(s), an IEntryAggregator and a result
evaluation filter.
|
![]() ![]() | CreateInstance(IValueExtractor, IEntryAggregator, IFilter) |
Create an instance of GroupAggregator based on a specified
extractor and an IEntryAggregator and a result
evaluation filter.
|
![]() | Equals |
Compare the GroupAggregator with another object to determine
equality.
(Overrides ObjectEquals(Object).) |
![]() | Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.) |
![]() | GetHashCode |
Determine a hash value for the GroupAggregator object according
to the general object.GetHashCode() contract.
(Overrides ObjectGetHashCode.) |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() | MemberwiseClone | Creates a shallow copy of the current Object. (Inherited from Object.) |
![]() | ReadExternal |
Restore the contents of a user type instance by reading its state
using the specified IPofReader object.
|
![]() | ToString |
Return a human-readable description for this GroupAggregator.
(Overrides ObjectToString.) |
![]() | WriteExternal |
Save the contents of a POF user type instance by writing its
state using the specified IPofWriter object.
|
Name | Description | |
---|---|---|
![]() | m_aggregator |
The underlying IEntryAggregator.
|
![]() | m_extractor |
The underlying IValueExtractor.
|
![]() | m_filter |
The IFilter object representing the "having" clause of this
"group by" aggregator.
|
The splitting (grouping) is performed using the results of the underlying IValueExtractor in such a way that two entries will belong to the same group if and only if the result of the corresponding Extract(Object) call produces the same value or tuple (list of values). After the entries are split into the groups, the underlying aggregator is applied separately to each group. The result of the aggregation by the GroupAggregator is a dictionary that has distinct values (or tuples) as keys and results of the individual aggregation as values. Additionally, those results could be further reduced using an optional IFilter object.
Informally speaking, this aggregator is analogous to the SQL "group by" and "having" clauses. Note that the "having" IFilter is applied independently on each server against the partial aggregation results; this generally implies that data affinity is required to ensure that all required data used to generate a given result exists within a single cache partition. In other words, the "group by" predicate should not span multiple partitions if the "having" clause is used.
The GroupAggregator is somewhat similar to the DistinctValues aggregator, which returns back a list of distinct values (tuples) without performing any additional aggregation work.
Unlike many other concrete IEntryAggregator implementations that are constructed directly, instances of GroupAggregator should only be created using one of the factory methods:
CreateInstance(IValueExtractor, IEntryAggregator)CreateInstance(IValueExtractor, IEntryAggregator, IFilter)CreateInstance(String, IEntryAggregator)CreateInstance(String, IEntryAggregator, IFilter)