ALL
Aplica-se a:Coluna calculadaTabela calculadaMedidaCálculo visual
Retorna todas as linhas de uma tabela ou todos os valores de uma coluna, ignorando quaisquer filtros que possam ter sido aplicados. Esta função é útil para limpar filtros e criar cálculos em todas as linhas de uma tabela.
Sintaxe
ALL( [<table> | <column>[, <column>[, <column>[,…]]]] )
Parâmetros
Vigência | Definição |
---|---|
table |
A tabela na qual você deseja limpar os filtros. |
column |
A coluna na qual você deseja limpar os filtros. |
O argumento para a função ALL deve ser uma referência a uma tabela base ou uma referência a uma coluna base. Não é possível usar expressões de tabela ou expressões de coluna com a função ALL.
Valor de retorno
A tabela ou coluna com filtros removidos.
Comentários
Esta função não é usada por si só, mas serve como uma função intermediária que pode ser usada para alterar o conjunto de resultados sobre o qual algum outro cálculo é realizado.
O comportamento normal para DAX expressões que contêm a função ALL() é que todos os filtros aplicados serão ignorados. No entanto, existem alguns cenários em que este não é o caso por causa do
auto-exist
, uma tecnologia DAX que otimiza a filtragem a fim de reduzir a quantidade de processamento necessário para determinadas consultas DAX. Um exemplo em que a autoexistência e o ALL() fornecem resultados inesperados é quando filtram em duas ou mais colunas da mesma tabela (como ao usar segmentações de dados) e há uma medida nessa mesma tabela que usa ALL(). Nesse caso, a existência automática mesclará vários filtros em um e filtrará apenas as combinações de valores existentes. Devido a essa mesclagem, a medida será calculada nas combinações de valores existentes e o resultado será baseado em valores filtrados em vez de todos os valores conforme o esperado. Para saber mais sobre a existência automática e seu efeito nos cálculos, consulte o artigo Understanding DAX Auto-Exist do Microsoft MVP Alberto Ferrari sobre sql.bi.com.A tabela a seguir descreve como você pode usar as funções ALL e ALLEXCEPT em diferentes cenários.
Função e utilização Descrição ALL() Remove todos os filtros em todos os lugares. ALL() só pode ser usado para limpar filtros, mas não para retornar uma tabela. ALL(Tabela) Remove todos os filtros da tabela especificada. Com efeito, ALL(Table) retorna todos os valores na tabela, removendo quaisquer filtros do contexto que, de outra forma, poderiam ter sido aplicados. Essa função é útil quando você está trabalhando com vários níveis de agrupamento e deseja criar um cálculo que cria uma proporção de um valor agregado para o valor total. O primeiro exemplo demonstra esse cenário. ALL (Coluna[, Coluna[, ...]]) Remove todos os filtros das colunas especificadas na tabela; Todos os outros filtros em outras colunas da tabela ainda se aplicam. Todos os argumentos de coluna devem vir da mesma tabela. A variante ALL(Coluna) é útil quando você deseja remover os filtros de contexto para uma ou mais colunas específicas e manter todos os outros filtros de contexto. O segundo e terceiro exemplos demonstram este cenário. ALLEXCEPT(Tabela, Coluna1 [,Coluna2]...) Remove todos os filtros de contexto na tabela, exceto os filtros aplicados às colunas especificadas. Este é um atalho conveniente para situações em que você deseja remover os filtros em muitas, mas não todas, colunas em uma tabela. Esta função não é suportada para utilização no modo DirectQuery quando utilizada em colunas calculadas ou regras de segurança ao nível da linha (RLS).
Exemplo 1
Calcular a relação entre Vendas por Categoria e Vendas Totais
Suponha que você deseja encontrar a quantidade de vendas para a célula atual, em sua Tabela Dinâmica, dividida pelo total de vendas para todos os revendedores. Para garantir que o denominador seja o mesmo, independentemente de como o usuário da Tabela Dinâmica possa estar filtrando ou agrupando os dados, defina uma fórmula que use ALL para criar o total geral correto.
A tabela a seguir mostra os resultados quando uma nova medida, All Reseller Sales Ratio, é criada usando a fórmula mostrada na seção de código. Para ver como isso funciona, adicione o campo, CalendarYear, à área Rótulos de Linha
Rótulos de linha | Acessórios | Bicicletas | Vestuário | Componentes | Total geral |
---|---|---|---|---|---|
2005 | 0,02% | 9,10% | 0,04% | 0,75% | 9,91% |
2006 | 0,11% | 24.71% | 0,60% | 4.48% | 29,90% |
2007 | 0,36% | 31,71% | 1,07% | 6.79% | 39,93% |
2008 | 0,20% | 16,95% | 0,48% | 2,63% | 20,26% |
Total geral | 0,70% | 82,47% | 2.18% | 14,65% | 100,00% |
Fórmula
= SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])/SUMX(ALL(ResellerSales_USD), ResellerSales_USD[SalesAmount_USD])
A fórmula é construída da seguinte forma:
O numerador,
SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])
, é a soma dos valores em ResellerSales_USD[SalesAmount_USD] para a célula atual na Tabela Dinâmica, com filtros de contexto aplicados em CalendarYear e ProductCategoryName.Para o denominador, você começa especificando uma tabela, ResellerSales_USD e usa a função ALL para remover todos os filtros de contexto na tabela.
Em seguida, use a função SUMX para somar os valores na coluna ResellerSales_USD[SalesAmount_USD]. Em outras palavras, você recebe a soma de ResellerSales_USD[SalesAmount_USD] para todas as vendas de revendedores.
Exemplo 2
Calcular a relação entre as vendas de produtos e o total de vendas ao longo do ano atual
Suponha que você deseja criar uma tabela mostrando a porcentagem de vendas comparadas ao longo dos anos para cada categoria de produto (ProductCategoryName). Para obter a porcentagem para cada ano sobre cada valor de ProductCategoryName, você precisa dividir a soma das vendas para esse ano específico e categoria de produto pela soma das vendas para a mesma categoria de produto em todos os anos. Em outras palavras, você deseja manter o filtro em ProductCategoryName, mas remover o filtro no ano ao calcular o denominador da porcentagem.
A tabela a seguir mostra os resultados quando uma nova medida, Ano de Vendas do Revendedor, é criada usando a fórmula mostrada na seção de código. Para ver como isso funciona, adicione o campo, CalendarYear, à área Rótulos de Linha
Rótulos de linha | Acessórios | Bicicletas | Vestuário | Componentes | Total geral |
---|---|---|---|---|---|
2005 | 3.48% | 11.03% | 1,91% | 5.12% | 9,91% |
2006 | 16.21% | 29,96% | 27,29% | 30,59% | 29,90% |
2007 | 51,62% | 38.45% | 48.86% | 46.36% | 39,93% |
2008 | 28,69% | 20,56% | 21,95% | 17,92% | 20,26% |
Total geral | 100,00% | 100,00% | 100,00% | 100,00% | 100,00% |
Fórmula
= SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])/CALCULATE( SUM( ResellerSales_USD[SalesAmount_USD]), ALL(DateTime[CalendarYear]))
A fórmula é construída da seguinte forma:
O numerador,
SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])
, é a soma dos valores em ResellerSales_USD[SalesAmount_USD] para a célula atual na tabela dinâmica, com filtros de contexto aplicados nas colunas CalendarYear e ProductCategoryName.Para o denominador, remova o filtro existente em CalendarYear usando a função ALL(Column). Isso calcula a soma sobre as linhas restantes na tabela ResellerSales_USD, depois de aplicar os filtros de contexto existentes dos rótulos de coluna. O efeito líquido é que, para o denominador, a soma é calculada sobre o ProductCategoryName selecionado (o filtro de contexto implícito) e para todos os valores em Year.
Exemplo 3
Calcular a contribuição das categorias de produtos para o total de vendas por ano
Suponha que você deseja criar uma tabela que mostra a porcentagem de vendas para cada categoria de produto, em uma base anual. Para obter a porcentagem para cada categoria de produto em um determinado ano, você precisa calcular a soma das vendas para essa categoria de produto específica (ProductCategoryName) no ano n e, em seguida, dividir o valor resultante pela soma das vendas para o ano n em todas as categorias de produtos. Em outras palavras, você deseja manter o filtro no ano, mas remover o filtro em ProductCategoryName ao calcular o denominador da porcentagem.
A tabela a seguir mostra os resultados quando uma nova medida, Reseller Sales CategoryName, é criada usando a fórmula mostrada na seção de código. Para ver como isso funciona, adicione o campo CalendarYear à área Rótulos de Linha
Rótulos de linha | Acessórios | Bicicletas | Vestuário | Componentes | Total geral |
---|---|---|---|---|---|
2005 | 0,25% | 91,76% | 0,42% | 7,57% | 100,00% |
2006 | 0,38% | 82,64% | 1,99% | 14,99% | 100,00% |
2007 | 0,90% | 79.42% | 2,67% | 17.01% | 100,00% |
2008 | 0,99% | 83,69% | 2,37% | 12,96% | 100,00% |
Total geral | 0,70% | 82,47% | 2.18% | 14,65% | 100,00% |
Fórmula
= SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])/CALCULATE( SUM( ResellerSales_USD[SalesAmount_USD]), ALL(ProductCategory[ProductCategoryName]))
A fórmula é construída da seguinte forma:
O numerador,
SUMX(ResellerSales_USD, ResellerSales_USD[SalesAmount_USD])
, é a soma dos valores em ResellerSales_USD[SalesAmount_USD] para a célula atual na Tabela Dinâmica, com filtros de contexto aplicados nos campos, CalendarYear e ProductCategoryName.Para o denominador, use a função ALL(Column) para remover o filtro em ProductCategoryName e calcular a soma sobre as linhas restantes na tabela ResellerSales_USD, depois de aplicar os filtros de contexto existentes dos rótulos de linha. O efeito líquido é que, para o denominador, a soma é calculada sobre o Ano selecionado (o filtro de contexto implícito) e para todos os valores de ProductCategoryName.