Иллюстрированный самоучитель по Delphi 7 для профессионалов

Компонент TDecisionCube

При помощи методов GetDetailsQL и GetSQL можно получить тексты запросов, которые возвращают набор данных, соответствующий кросстабу с заданным параметрами состояниями. Массив vaiueArray содержит условия для полей размерностей. Первой размерности соответствует первый элемент массива, второй размерности – второй элемент и т. д.

Если значение элемента меньше нуля, то в результат запроса попадают все значения поля размерности. Значение элемента, равное или больше нуля, определяет индекс значения поля размерности. Параметр selectList содержит разделенный запятыми список дополнительных полей, которые нужно включить в запрос. Параметр bActive накладывает дополнительное ограничение на размерности. При значении True в результат запроса автоматически (без использования параметра selectList) попадают только активные размерности.

Ключевым свойством компонента является свойство DecisionMap, которое позволяет установить параметры размерностей и максимальный размер используемой памяти. Для этих целей применяется специализированный редактор (см. рис. 30.4).

Это свойство представляет собой экземпляр класса TCubeDims, который инкапсулирует индексированный список экземпляров объектов TCubeDim, каждый из которых содержит информацию о параметрах одной размерности. Основные свойства этого класса представлены в табл. 30.3.

Таблица 30.3. Основные свойства класса TCubeDim.

Объявление Тип Описание
type TActiveFlags = (diActive, diAsNeeded, dilnactive);
property ActiveFlag: TActiveFlags;
Pb Определяет режим отображения данных размерности
property BaseName: string; Pb Содержит имя поля размерности в таблице базы данных
property BinFormat: string; Pu Определяет способ форматирования диапазона значений размерности
type TBinType = (binNone, binYear, binQuarter, binMonth, binSet, binCustom);
property BinType: TBinType;
Pb Определяет способ группирования данных в размерности
type TDimFlags = (dimDimension, dimSum, dimCount, dimAverage, dimMin, dimMax, dimGenericAgg, dimUnknown);
property DimensionType: TDimFlags;
Pb Определяет тип размерности
property FieldName: String; Pb Содержит имя поля в наборе данных
property FieldType: TFieldType; Pu Определяет тип поля
property Format: String; Pu Задает форматирование данных размерности
property Loaded: Boolean; Ro Значение True говорит о том, что данный элемент загружен в многомерный набор данных
property StartDate: TDate; Pu Определяет начальный элемент для группировки по дате
property StartValue: String; Pu Определяет начальный элемент: для группировки по значению
property ValueCount: Integer; Pb Возвращает число уникальных элементов в размерности
Если Вы заметили ошибку, выделите, пожалуйста, необходимый текст и нажмите CTRL + Enter, чтобы сообщить об этом редактору.