Compartilhar via


Rank (MDX)

Retorna a classificação de base um de uma tupla especificada em um conjunto especificado.

Sintaxe

  
Rank(Tuple_Expression, Set_Expression [ ,Numeric Expression ] )  

Argumentos

Tuple_Expression
Uma linguagem MDX válida que retorna uma tupla.

Set_Expression
Uma expressão MDX (Expressões Multidimensionais) válida que retorna um conjunto.

Numeric_expression
Uma expressão numérica válida, geralmente uma linguagem MDX de coordenadas de célula, que retorna um número.

Comentários

Se uma expressão numérica for especificada, a função Rank determinará a classificação baseada em um para a tupla especificada avaliando a expressão numérica especificada em relação à tupla. Se uma expressão numérica for especificada, a função Rank atribuirá a mesma classificação a tuplas com valores duplicados no conjunto. Essa atribuição da mesma classificação para valores duplicados afeta as classificações de tuplas subsequentes no conjunto. Por exemplo, um conjunto é formado pelas seguintes tuplas, {(a,b), (e,f), (c,d)}. A tupla (a,b) tem o mesmo valor que a tupla (c,d). Se a tupla (a,b) tiver uma classificação 1, então tanto (a,b) quanto (c,d) terão uma classificação 1. No entanto, a tupla (e,f) teria uma classificação 3. Não poderia haver uma tupla com classificação 2 nesse conjunto.

Se uma expressão numérica não for especificada, a função Rank retornará a posição ordinal baseada em um da tupla especificada.

A função Rank não ordena o conjunto.

Exemplo

O exemplo a seguir retorna o conjunto de tuplas que contêm clientes e datas de compra, usando as funções Filter, NonEmpty, Item e Rank para encontrar a última data em que cada cliente fez uma compra.

WITH SET MYROWS AS FILTER  
   (NONEMPTY  
      ([Customer].[Customer Geography].MEMBERS  
         * [Date].[Date].[Date].MEMBERS  
         , [Measures].[Internet Sales Amount]  
      ) AS MYSET  
   , NOT(MYSET.CURRENT.ITEM(0)  
      IS MYSET.ITEM(RANK(MYSET.CURRENT, MYSET)).ITEM(0))  
   )  
SELECT [Measures].[Internet Sales Amount] ON 0,  
MYROWS ON 1  
FROM [Adventure Works]  

O exemplo a seguir usa a função Order , em vez da função Rank , para classificar os membros da hierarquia cidade com base na medida Valor de Vendas do Revendedor e, em seguida, exibe-os em ordem classificada. Usando a função Order para ordenar primeiro o conjunto de membros da hierarquia cidade, a classificação é feita apenas uma vez e, em seguida, seguida por uma verificação linear antes de ser apresentada em ordem classificada.

WITH   
SET OrderedCities AS Order  
   ([Geography].[City].[City].members  
   , [Measures].[Reseller Sales Amount], BDESC  
   )  
MEMBER [Measures].[City Rank] AS Rank  
   ([Geography].[City].CurrentMember, OrderedCities)  
SELECT {[Measures].[City Rank],[Measures].[Reseller Sales Amount]}  ON 0   
,Order  
   ([Geography].[City].[City].MEMBERS  
   ,[City Rank], ASC)  
    ON 1  
FROM [Adventure Works]  

Consulte Também

Order (MDX)
Referência de função MDX (MDX)