Инструкция CREATE GLOBAL CUBE (многомерные выражения)
Изменения: 12 декабря 2006 г.
Создает и заполняет значениями локально материализованный куб на основе вложенного куба из куба на сервере. Чтобы подключиться к локально материализованному кубу, соединяться с сервером необязательно. Дополнительные сведения о локальных кубах см. в разделе Локальные кубы и модели интеллектуального анализа данных (службы Analysis Services).
Синтаксис
CREATE GLOBAL CUBE local_cube_name STORAGE 'Cube_Location'
FROM source_cube_name (<param list>)
<param list>::= <param> ,<param list> | <param>
<param>::= <dims list> | <measures list>
<measures list>::= <measure>[, <measures list>]
<dims list>::= <dim def> [, <dims list>]
<measure>::= MEASURE source_cube_name.measure_name [<visibility qualifier>] [AS measure_name]
<dim def>::= <source dim def> | <derived dim def>
<source dim def>::= DIMENSION source_cube_name.dimension_name [<dim flags>] [<visibility qualifier>] [AS dimension_name>] [FROM <dim from clause> ] [<dim content def>]
<dim flags>::= NOT_RELATED_TO_FACTS
<dim from clause>::= < dim DM from clause> | <reg dim from clause>
<dim DM from clause>::= dm_model_name> COLUMN column_name
<dim reg from clause>::= dimension_name
<dim content def>::= ( <level list> [,<grouping list>] [,<member slice list>] [,<default member>] )
<level list>::= <level def> [, <level list>]
<level def>::= LEVEL level_name [<level type> ] [AS level_name] [<level content def>]
<level content def>::= ( <property list> ) | NO_PROPERTIES
<level type>::= GROUPING
<property list>::= <property def> [, <property list>]
<property def>::= PROPERTY property_name
<grouping list>::= <grouping entity> [,<grouping list>]
<grouping entity>::= GROUP group_level_name.group_name (<mixed list>)
<grp mixed list>::= <grp mixed element> [,<grp mixed list>]
<grp mixed element>::= <grouping entity> | <member def>
<member slice list>::= <member list>
<member list>::= <member def> [, <member list>]
<member def>::= MEMBER member_name
<default member>::= DEFAULT_MEMBER AS MDX_expression
<visibility qualifier>::= HIDDEN
Элементы синтаксиса
- local_cube_name
Имя локального куба.
- 'Cube_Location'
Путь и имя локально материализованного куба.
- source_cube_name
Имя куба, на котором основан локальный куб.
- source_cube_name.measure_name
Полное имя исходной меры, включаемой в локальный куб. Вычисляемые элементы измерения «Меры» недопустимы.
- measure_name
Имя меры в локальном кубе.
- source_cube_name.dimension_name
Полное имя исходного измерения, включаемого в локальный куб.
- dimension_name
Имя измерения в локальном кубе.
- FROM <dim from clause>
Спецификация, допустимая только для определения производного измерения.
- NOT_RELATED_TO_FACTS
Спецификация, допустимая только для определения производного измерения.
- <level type>
Спецификация, допустимая только для определения производного измерения.
Замечания
Локальный куб определяется на основе мер и измерений, которые его определяют. Существует два типа измерений.
- Измерения источника — это измерения, которые были частью одного из исходных кубов.
- Производные измерения — это измерения, которые обеспечивают новые возможности анализа. Производным измерением может являться обычное измерение, определенное на основе исходного измерения, которое является горизонтальным или вертикальным срезом либо содержит пользовательское группирование элементов измерения. Производным также может быть измерение интеллектуального анализа данных, основанное на модели интеллектуального анализа данных.
Примечание. |
---|
Ключевое слово «измерение» может относиться либо к измерениям, либо к иерархиям. |
В локальном кубе можно выполнять следующие задачи:
- Исключать измерения, которые существуют в исходном кубе.
- Добавлять или исключать иерархии из измерения.
- Исключать группы мер или определенные меры.
Инструкция CREATE GLOBAL CUBE удовлетворяет следующим правилам.
- Инструкция CREATE GLOBAL CUBE автоматически копирует все команды, такие как вычисляемые меры и действия, в локальный куб. Локальный куб не может выполнить команду, если она содержит многомерное выражение, явно ссылающееся на родительский куб. Во избежание этой проблемы необходимо при определении многомерных выражений для команд использовать ключевое слово CURRENTCUBE. Ключевое слово CURRENTCUBE использует контекст текущего куба для обращения к кубу в многомерном выражении.
- Глобальный куб, созданный из существующего глобального куба в локальном файле, нельзя сохранить в тот же файл. Создайте глобальный куб SalesLocal1 и сохраните в файле C:\SalesLocal.cub. Затем выполняется подключение к файлу C:\SalesLocal.cub и создается второй глобальный куб SalesLocal2. При попытке сохранения глобального куба SalesLocal2 в файл C:\SalesLocal.cub возникнет ошибка. Глобальный куб SalesLocal2 можно сохранить только в отдельный файл локального куба.
- Глобальные кубы не поддерживают меры числа различных объектов. Поскольку кубы, которые содержат эти меры, не являются аддитивными, инструкция CREATE GLOBAL CUBE не поддерживает создание и использование мер числа различных объектов.
- При добавлении в локальный куб меры необходимо также включить по крайней мере одно измерение, относящееся к добавляемой мере.
- При добавлении иерархии типа «родители-потомки» в локальный куб уровни и фильтры иерархии типа «родители-потомки» не обрабатываются и добавляется вся иерархия целиком.
- Свойства элементов в локальных кубах не поддерживаются.
- Создать локальный куб из перспективы невозможно.
- При добавлении в локальный куб полуаддитивной меры применяются следующие правила.
- Если свойство AggregateFunction для добавляемой меры равно ByAccount, то необходимо добавить измерение счетов.
- Если свойство AggregateFunction для добавляемой меры равно FirstChild, LastChild, FirstNonEmpty, LastNonEmpty или AverageOfChildren, то необходимо полностью добавить измерение времени.
- Измерения интеллектуального анализа данных не могут быть добавлены в локальный куб.
- Ссылочные измерения материализуются и добавляются как обычные измерения.
- При добавлении измерения «многие ко многим» применяются следующие правила.
- Измерение «многие ко многим» должно быть добавлено полностью.
- Необходимо добавить промежуточную группу мер.
- Необходимо добавить сущность всех измерений, общих для двух групп мер, включенных в связь «многие ко многим».
В следующем примере демонстрируется создание локального, сохраненного варианта куба Adventure Works, в котором содержится только мера Reseller Sales Amount и измерения Reseller и Date.
CREATE GLOBAL CUBE [LocalReseller]
Storage 'C:\LocalAWReseller1.cub'
FROM [Adventure Works]
(
MEASURE [Adventure Works].[Reseller Sales Amount],
DIMENSION [Adventure Works].[Reseller],
DIMENSION [Adventure Works].[Date]
)
В следующем примере иллюстрируется использование срезов при создании локального куба. Глобальный куб создается на основе куба Adventure Works путем среза по вертикали по элементу 2005 уровня Fiscal Year и по горизонтали по уровням Fiscal Year и Month.
CREATE GLOBAL CUBE [LocalReseller]
Storage 'C:\LocalAWReseller2.cub'
FROM [Adventure Works]
(
MEASURE [Adventure Works].[Reseller Sales Amount],
DIMENSION [Adventure Works].[Reseller],
DIMENSION [Adventure Works].[Date]
(
LEVEL [Fiscal Year],
LEVEL [Month],
MEMBER [Date].[Fiscal].[Fiscal Year].&[2005]
)
)
См. также
Справочник
Инструкция CREATE SESSION CUBE (многомерные выражения)
Другие ресурсы
Инструкции определения данных многомерных выражений
Справка и поддержка
Получение помощи по SQL Server 2005
Журнал изменений
Версия | Журнал |
---|---|
12 декабря 2006 г. |
|
17 июля 2006 г. |
|