Compartilhar via


Membros calculados em subseleções e subcubos

Nas versões anteriores, os membros calculados não eram permitidos em subseleções ou subcubos. No entanto, desde o SQL Server 2008, eles são permitidos e habilitados por uma propriedade de conexão. Além disso, um novo comportamento para membros calculados, em subseleções e subcubos, foi introduzido no SQL Server 2008 R2.

Membros calculados em subseleções e subcubos

A propriedade da cadeia de caracteres de conexão SubQueries em ConnectionString ou a propriedade DBPROPMSMDSUBQUERIES em Propriedades XMLA suportadas (XMLA) define o comportamento ou a permissão de membros ou conjuntos calculados em subseleções ou subcubos. No contexto deste documento, subseleção se refere a subseleções e subcubos, exceto quando indicado o contrário.

A propriedade SubQueries permite os seguintes valores.

Valor

Descrição

0

Os membros calculados não são permitidos em subseleções ou subcubos.

Ocorrerá um erro durante a avaliação da subseleção ou do subcubo se um membro calculado for referenciado.

1

Os membros calculados são permitidos em subseleções ou subcubos, mas nenhum membro ascendente é introduzido no subespaço retornando.

2

Os membros calculados são permitidos em subseleções e subcubos, mas nenhum membro ascendente é introduzido no subespaço retornando. Além disso, a granularidade mista é permitida na seleção de membros calculados.

O uso de valores de 1 ou 2 na propriedade SubQueries permite que membros calculados sejam usados para filtrar o subespaço retornando de subseleções.

Um exemplo ajudará a esclarecer o conceito; primeiro, um membro calculado deve ser criado e, em seguida, uma consulta de subseleção é emitida para mostrar o comportamento acima.

O exemplo a seguir cria um membro calculado que adiciona [Seattle Metro] como uma cidade à hierarquia [Geography].[Geography] no estado de Washington.

Para executar o exemplo, a cadeia de conexão deve conter a propriedade SubQueries com um valor igual a 1 e todas as instruções MDX devem ser executadas na mesma sessão.

Primeiro emita a seguinte expressão MDX:

//Remember to set Subqueries=1 in the connection string prior
//to issue these commands
//--> AS2008 behavior
CREATE MEMBER [Adventure Works].[Geography].[Geography].[State-Province].&[WA]&[US].[Seattle Metro Agg] 
   AS  AGGREGATE( 
                 { 
                   [Geography].[Geography].[City].&[Bellevue]&[WA]
                 , [Geography].[Geography].[City].&[Issaquah]&[WA]
                 , [Geography].[Geography].[City].&[Redmond]&[WA]
                 , [Geography].[Geography].[City].&[Seattle]&[WA]
                 }
                )  

Em seguida, emita a consulta MDX a seguir para ver os membros calculados permitidos em subseleções.

Select [Date].[Calendar Year].members on 0,
       [Geography].[Geography].allmembers on 1
from (Select {[Geography].[Geography].[State-Province].&[WA]&[US].[Seattle Metro Agg]} on 0 from [Adventure Works])
Where [Measures].[Reseller Sales Amount]

Os resultados obtidos são:

 

All Periods

CY 2001

CY 2002

CY 2003

CY 2004

Seattle Metro Agg

$2,383,545.69

$291,248.93

$763,557.02

$915,832.36

$412,907.37

Como já dissemos, os ascendentes de [Seattle Metro] não existem no subespaço retornado, quando SubQueries=1, logo, [Geography].[Geography].allmembers só contém o membro calculado.

Se o exemplo for executado usando-se SubQueries=2, na cadeia de conexão, os resultados obtidos serão:

 

All Periods

CY 2001

CY 2002

CY 2003

CY 2004

All Geographies

(null)

(null)

(null)

(null)

(null)

United States

(null)

(null)

(null)

(null)

(null)

Washington

(null)

(null)

(null)

(null)

(null)

Seattle Metro Agg

$2,383,545.69

$291,248.93

$763,557.02

$915,832.36

$412,907.37

Como já dissemos, ao usarem SubQueries=2, os ascendentes de [Seattle Metro] estão no subespaço retornado, mas não há nenhum valor para esses membros porque não existe nenhum membro regular a ser fornecido para as agregações. Por isso, os valore NULL são fornecidos para todos os membros ascendentes do membro calculado desse exemplo.

Para compreender o comportamento acima, você precisa se lembrar do fato de que os membros calculados não contribuem para as agregações dos pais como acontece com os membros regulares. Consulte Calculated Members and Named Sets. O primeiro indica que a filtragem apenas por membros calculados levará a ascendentes vazios porque não há nenhum membro regular de contribuição para os valores agregados do subespaço resultante. Se você adicionar membros regulares à expressão de filtragem, os valores agregados virão desses membros regulares. Continuando o exemplo anterior, se as cidades de Portland, em Oregon, e de Spokane, em Washington, forem adicionadas ao mesmo eixo onde o membro calculado é exibido; como mostrado na próxima expressão MDX:

Select [Date].[Calendar Year].members on 0,
       [Geography].[Geography].allmembers on 1
from (Select {
               [Seattle Metro Agg]
             , [Geography].[Geography].[City].&[Portland]&[OR]
             , [Geography].[Geography].[City].&[Spokane]&[WA]
             } on 0 from [Adventure Works]
     )
Where [Measures].[Reseller Sales Amount]

Os resultados a seguir são obtidos.

 

All Periods

CY 2001

CY 2002

CY 2003

CY 2004

All Geographies

$235,171.62

$419.46

$4,996.25

$131,788.82

$97,967.09

United States

$235,171.62

$419.46

$4,996.25

$131,788.82

$97,967.09

Oregon

$30,968.25

$419.46

$4,996.25

$17,442.97

$8,109.56

Portland

$30,968.25

$419.46

$4,996.25

$17,442.97

$8,109.56

97205

$30,968.25

$419.46

$4,996.25

$17,442.97

$8,109.56

Washington

$204,203.37

(null)

(null)

$114,345.85

$89,857.52

Spokane

$204,203.37

(null)

(null)

$114,345.85

$89,857.52

99202

$204,203.37

(null)

(null)

$114,345.85

$89,857.52

Seattle Metro Agg

$2,383,545.69

$291,248.93

$763,557.02

$915,832.36

$412,907.37

Nos resultados acima, os valores agregados para [All Geographies], [United States], [Oregon] e [Washington] vêm da agregação dos descendentes de &[Portland]&[OR] and &[Spokane]&[WA]. Nada vem do membro calculado.

Comentários

Apenas membros globais ou calculados pela sessão são permitidos nas expressões de subseleção ou subcubo. Os membros calculados da consulta na expressão MDX irão gerar um erro quando a expressão de subseleção ou subcubo for avaliada.