Для вычисления агрегатных выражений для всех записей набора данных используются объекты класса
TAggregate. Индексированный список этих объектов содержится в свойстве
property Aggregates: TAggregates;
компонента TClientDataSet. Прямым предком класса
TAggregates является класс
TCollection, поэтому для него можно использовать все основные приемы работы с коллекциями (см. гл. 7).
Для создания нового агрегата необходимо щелкнуть на кнопке свойства в Инспекторе объектов и, в появившемся Редакторе агрегатов, выбрать пункт
Add во всплывающем меню или щелкнуть на кнопке
Add New (рис. 22.3).
Новый агрегат может быть добавлен и динамически:
var NewAgg: TAggregate;
NewAgg := ClientDataSet.Aggregates.Add;
Рис. 22.3. Редактор агрегатов
компонента TClientDataSet
Рассмотрим свойства класса TAggregate.
Имя агрегата содержится в свойстве
property AggregateName:
string;
которое может быть использовано при отображении
агрегата в визуальных компонентах.
Вычисляемое выражение с применением агрегатных
функций должно находиться в свойстве
property Expression:
String;
Например, для таблицы COUNTRY.DB из демонстрационной
базы данных Delphi можно вычислять общую площадь государств Северной и Южной
Америки (площадь государства содержится в поле Area):
Для проверки активности агрегата, помимо проверки
значения свойства Active, можно также использовать
свойство
property InUse:
Boolean;
Если оно возвращает значение
True — вычисляемое выражение агрегата рассчитывается.
Видимость агрегата в визуальных компонентах
управляется свойством
property Visible:
Boolean;
Для того чтобы снизить вычислительную нагрузку
на набор данных, можно отключить все агрегаты одновременно. Для этого свойству
property AggregatesActive:
Boolean;
необходимо присвоить значение False.
Если же AggregatesActive
= True, вычисляются только активные агрегаты, для которых свойство Active
имеет значение True.
Если вам необходимо использовать все активные
агрегаты, то вместо их последовательного перебора с проверкой свойства
Active можно использовать свойство
property ActiveAggs[Index:
Integer] : TList;
компонента TClientDataSet,
которое представляет собой список активных агрегатов.
Знаете ли Вы, что cогласно релятивистской мифологии "гравитационное линзирование - это физическое явление, связанное с отклонением лучей света в поле тяжести. Гравитационные линзы обясняют образование кратных изображений одного и того же астрономического объекта (квазаров, галактик), когда на луч зрения от источника к наблюдателю попадает другая галактика или скопление галактик (собственно линза). В некоторых изображениях происходит усиление яркости оригинального источника." (Релятивисты приводят примеры искажения изображений галактик в качестве подтверждения ОТО - воздействия гравитации на свет) При этом они забывают, что поле действия эффекта ОТО - это малые углы вблизи поверхности звезд, где на самом деле этот эффект не наблюдается (затменные двойные). Разница в шкалах явлений реального искажения изображений галактик и мифического отклонения вблизи звезд - 1011 раз. Приведу аналогию. Можно говорить о воздействии поверхностного натяжения на форму капель, но нельзя серьезно говорить о силе поверхностного натяжения, как о причине океанских приливов. Эфирная физика находит ответ на наблюдаемое явление искажения изображений галактик. Это результат нагрева эфира вблизи галактик, изменения его плотности и, следовательно, изменения скорости света на галактических расстояниях вследствие преломления света в эфире различной плотности. Подтверждением термической природы искажения изображений галактик является прямая связь этого искажения с радиоизлучением пространства, то есть эфира в этом месте, смещение спектра CMB (космическое микроволновое излучение) в данном направлении в высокочастотную область. Подробнее читайте в FAQ по эфирной физике.