To specify that you want to calculate summaries over the records in a client dataset, use the Aggregates property. Aggregates is a collection of aggregate specifications (TAggregate). You can add aggregate specifications to your client dataset using the Collection Editor at design time, or using the Add method of Aggregates at runtime. If you want to create field components for the aggregates, create persistent fields for the aggregated values in the Fields Editor.
Sum(Field1)
or a complex expression that combines information from several fields, such as
Sum(Qty * Price) - Sum(AmountPaid)
Aggregate expressions include one or more of the summary operators in the following table
Summary operators for maintained aggregates
Operator |
Use |
Sum |
Totals the values for a numeric field or expression |
Avg |
Computes the average value for a numeric or date-time field or expression |
Count |
Specifies the number of non-blank values for a field or expression |
Min |
Indicates the minimum value for a string, numeric, or date-time field or expression |
Max |
Indicates the maximum value for a string, numeric, or date-time field or expression |
The summary operators act on field values or on expressions built from field values using the same operators you use to create filters. (You can't nest summary operators, however.) You can create expressions by using operators on summarized values with other summarized values, or on summarized values and constants. However, you can't combine summarized values with field values, because such expressions are ambiguous (there is no indication of which record should supply the field value.) These rules are illustrated in the following expressions:
Sum(Qty * Price) |
{legal -- summary of an expression on fields } |
Max(Field1) - Max(Field2) |
{legal -- expression on summaries } |
Avg(DiscountRate) * 100 |
{legal -- expression of summary and constant } |
Min(Sum(Field1)) |
{illegal -- nested summaries } |
Count(Field1) - Field2 |
{illegal -- expression of summary and field } |
Copyright(C) 2009 Embarcadero Technologies, Inc. All Rights Reserved.
|
What do you think about this topic? Send feedback!
|