Partilhar via


Script MDX – SCOPE

Limita o escopo de instruções MDX especificadas a um subcubo especificado.

Sintaxe

  
SCOPE(Subcube_Expression)   
   [ MDX_Statement ]  
END SCOPE  
  
Subcube_Expression ::=(Auxiliary_Subcube [, Auxiliary_Subcube,...n])  
  
Auxiliary_Subcube ::=   
        Limited_Set   
    | Root([dimension_name])   
    | Leaves([dimension_name])  
  
Limited_Set ::=   
        single_tuple   
    | member   
    | Common_Grain_Members   
    | hierarchy.members   
    | level.members   
    | {}   
    | Descendants  
            (  
                  Member  
         , [level  
         [  
            , SELF   
             | AFTER   
                          | BEFORE   
                          | SELF_AND_AFTER   
                          | SELF_AND_BEFORE   
                          | SELF_BEFORE_AFTER   
                          | LEAVES  
                  ]  
            )   
[* <limited set>]  

Argumentos

Subcube_Expression
Uma expressão de subcubo do MDX válida.

MDX_Statement
Uma instrução MDX válida.

Common_Grain_Members
Uma instrução MDX que é avaliada como membros que tem o mesmo grão.

single_tuple
Uma única tupla.

Comentários

A instrução SCOPE determina o subcubo que será afetado pela execução de uma ou mais instruções MDX. A menos que uma instrução MDX seja incluída em uma instrução SCOPE, o escopo implícito de uma instrução MDX é o cubo inteiro.

Observação

Membros escondidos estão expostos em instruções SCOPE.

As instruções SCOPE criarão subcubos que expõem "buracos", independentemente da configuração de compatibilidade do MDX . Por exemplo, a instrução Scope( Customer.State.members ) pode incluir os estados nos países ou regiões que não contêm os estados, mas para os quais os membros de placeholder invisíveis foram inseridos.

Os membros calculados e os conjuntos nomeados criados em uma instrução SCOPE não são afetados por essa instrução.

Exemplo

O exemplo a seguir, do script de cálculo MDX na solução de exemplo adventure works, define o escopo atual como trimestre fiscal no ano fiscal de 2005 e a medida de cota de valor de vendas e atribui um valor às células no escopo atual usando a função ParallelPeriod . Em seguida, o exemplo modifica o escopo usando outra instrução SCOPE e, em seguida, executa outra atribuição usando a função This (MDX ).

Scope   
 (   
    [Date].[Fiscal Year].&[2005],  
    [Date].[Fiscal].[Fiscal Quarter].Members,  
    [Measures].[Sales Amount Quota]  
 ) ;     
  
   This = ParallelPeriod                               
          (   
             [Date].[Fiscal].[Fiscal Year], 1,  
             [Date].[Fiscal].CurrentMember   
          ) * 1.35 ;  
  
/*-- Allocate equally to months in FY 2002 -----------------------------*/  
  
  Scope   
  (   
     [Date].[Fiscal Year].&[2002],  
     [Date].[Fiscal].[Month].Members   
  ) ;     
  
    This = [Date].[Fiscal].CurrentMember.Parent / 3 ;     
  
  End Scope ;     
End Scope ;     

Consulte Também

Instruções de script MDX (MDX)