Entrar com a conta da Microsoft
Entrar ou criar uma conta.
Olá,
Selecionar uma conta diferente.
Você tem várias contas
Escolha a conta com a qual você deseja entrar.

Tabelas de datas no Power Pivot são essenciais para navegar e calcular dados ao longo do tempo. Este artigo fornece uma compreensão completa das tabelas de datas e como você pode criá-las no Power Pivot. Em particular, este artigo descreve:

  • Por que uma tabela de datas é importante para navegar e calcular dados por datas e hora.

  • Como usar o Power Pivot para adicionar uma tabela de datas ao Modelo de Dados.

  • Como criar novas colunas de data, como Ano, Mês e Período em uma tabela de datas.

  • Como criar relações entre tabelas de data e tabelas de fatos.

  • Como trabalhar com o tempo.

Este artigo destina-se a usuários novos no Power Pivot. No entanto, é importante já ter uma boa compreensão da importação de dados, da criação de relações e da criação de colunas e medidas calculadas.

Este artigo não descreve como usar o DAX Time-Intelligence funções em fórmulas de medida. Para obter mais informações sobre como criar medidas com funções do DAX Time Intelligence, consulte Time Intelligence no Power Pivot no Excel.

Observação: No Power Pivot, os nomes "measure" e "calculated field" são sinônimos. Estamos usando a medida de nome ao longo deste artigo. Para obter mais informações, consulte Medidas no Power Pivot.

Sumário

Entender tabelas de datas

Quase todas as análises de dados envolvem navegar e comparar dados em datas e hora. Por exemplo, você pode querer somar valores de vendas para o último trimestre fiscal e, em seguida, comparar esses totais com outros trimestres, ou talvez você queira calcular um saldo de fechamento de final de mês para uma conta. Em cada um desses casos, você está usando datas como uma forma de agrupar e agregar transações ou saldos de vendas por um determinado período de tempo.

Relatório do Power View

Tabela dinâmica de vendas totais por trimestre fiscal

Uma tabela de datas pode conter muitas representações diferentes de datas e hora. Por exemplo, uma tabela de datas geralmente terá colunas como Ano Fiscal, Mês, Trimestre ou Período que você pode selecionar como campos de uma Lista de Campos ao cortar e filtrar seus dados em tabelas dinâmicas ou relatórios do Power View.

Lista de Campos do Power View

Lista de Campo do Power View

Para que colunas de datas como Ano, Mês e Trimestre incluam todas as datas dentro de seu respectivo intervalo, a tabela de datas deve ter pelo menos uma coluna com um conjunto contíguo de datas. Ou seja, essa coluna deve ter uma linha para cada dia para cada ano incluído na tabela de datas.

Por exemplo, se os dados que você deseja procurar tiverem datas de 1º de fevereiro de 2010 a 30 de novembro de 2012 e você relatar um ano civil, você desejará uma tabela de datas com pelo menos um intervalo de datas de 1º de janeiro de 2010 a 31 de dezembro de 2012. Todos os anos em sua tabela de datas devem conter todos os dias para cada ano. Se você estiver atualizando regularmente seus dados com dados mais recentes, talvez deseje executar a data final em um ou dois anos, para que você não precise atualizar sua tabela de datas conforme o tempo passa.

Tabela de datas com um conjunto contíguo de datas

Tabela de data com datas contíguas

Se você relatar um ano fiscal, poderá criar uma tabela de datas com um conjunto contíguo de datas para cada ano fiscal. Por exemplo, se o ano fiscal começar em 1º de março e você tiver dados para os exercícios de 2010 até a data atual (por exemplo, em FY 2013), você poderá criar uma tabela de datas que começa em 3/1/2009 e inclui pelo menos todos os dias em cada ano fiscal até a última data do Ano Fiscal de 2013.

Se você relatar o ano civil e o ano fiscal, não precisará criar tabelas de datas separadas. Uma única tabela de datas pode incluir colunas para um ano civil, ano fiscal e até mesmo um calendário de treze quatro semanas. O importante é que sua tabela de datas contém um conjunto contíguo de datas para todos os anos incluídos.

Adicionando uma tabela de datas ao Modelo de Dados

Há várias maneiras de adicionar uma tabela de datas ao modelo de dados:

  • Importe de um banco de dados relacional ou de outra fonte de dados.

  • Create uma tabela de datas no Excel e, em seguida, copie ou vincule a uma nova tabela no Power Pivot.

  • Importar do Microsoft Azure Marketplace.

Vamos examinar cada um deles mais de perto.

Importar de um banco de dados relacional

Se você importar alguns ou todos os seus dados de um data warehouse ou outro tipo de banco de dados relacional, as chances são de que já haja uma tabela de datas e relações entre ele e o restante dos dados que você está importando. As datas e o formato provavelmente corresponderão às datas em seus dados de fato, e as datas provavelmente começam bem no passado e vão longe no futuro. A tabela de datas que você deseja importar pode ser muito grande e conter um intervalo de datas além do que você precisará incluir em seu Modelo de Dados. Você pode usar os recursos avançados de filtro do Assistente de Importação de Tabela do Power Pivot para escolher seletivamente apenas as datas e as colunas específicas de que você realmente precisa. Isso pode reduzir significativamente o tamanho da pasta de trabalho e melhorar o desempenho.

Assistente de Importação de Tabela

Caixa de diálogo do Assistente de importação de tabela

Na maioria dos casos, você não precisará criar colunas adicionais como Ano Fiscal, Semana, Nome do Mês, etc. porque elas já existirão na tabela importada. No entanto, em alguns casos, depois de ter a tabela de datas importada para o Modelo de Dados, talvez seja necessário criar colunas de data adicionais, dependendo de uma necessidade específica de relatório. Felizmente, isso é fácil de fazer usando DAX. Você aprenderá mais sobre como criar campos de tabela de datas mais tarde. Cada ambiente é diferente. Se você não tiver certeza se suas fontes de dados têm uma data ou tabela de calendário relacionada, converse com o administrador do banco de dados.

Create uma tabela de datas no Excel

Você pode criar uma tabela de datas no Excel e copiá-la em uma nova tabela no Modelo de Dados. Isso é realmente muito fácil de fazer e lhe dá muita flexibilidade.

Ao criar uma tabela de datas no Excel, você começa com uma única coluna com um intervalo contíguo de datas. Em seguida, você pode criar colunas adicionais como Ano, Trimestre, Mês, Ano Fiscal, Período etc. na planilha do Excel usando fórmulas do Excel ou, depois de copiar a tabela no Modelo de Dados, você pode criá-las como colunas calculadas. A criação de colunas de data adicionais no Power Pivot é descrita na seção Adicionar novas colunas de data à seção Tabela de Datas posteriormente neste artigo.

Como: Create uma tabela de datas no Excel e copiá-la no Modelo de Dados

  1. No Excel, em uma planilha em branco, na célula A1, digite um nome de cabeçalho de coluna para identificar um intervalo de datas. Normalmente, isso seráalgo como Date, DateTime ou DateKey.

  2. Na célula A2, digite uma data de início. Por exemplo, 1/1/2010.

  3. Clique no identificador de preenchimento e arraste-o para baixo para um número de linha que inclui uma data de término. Por exemplo, 31/12/2016.

    Coluna de data no Excel

  4. Selecione todas as linhas na coluna Data (incluindo o nome do cabeçalho na célula A1).

  5. No grupo Estilos , clique em Formatar como Tabela e selecione um estilo.

  6. Na caixa de diálogo Formatar como Tabela, clique em OK.

    Coluna de data no Power Pivot

  7. Copie todas as linhas, incluindo o cabeçalho.

  8. No Power Pivot, na guia Página Inicial , clique em Colar.

  9. Em Colar Visualização > Nome da Tabela digite um nome como Data ou Calendário. Deixe Usar a primeira linha como cabeçalhos de coluna verificadose clique em OK.

    Visualização de Colagem

    A nova tabela de datas (chamada Calendário neste exemplo) no Power Pivot tem a seguinte aparência:

    Tabela de data no Power Pivot

    Observação: Você também pode criar uma tabela vinculada usando Adicionar ao Modelo de Dados. No entanto, isso torna sua pasta de trabalho desnecessariamente grande porque a pasta de trabalho tem duas versões da tabela de datas; um no Excel e outro no Power Pivot..

Observação: A data do nome é um palavra-chave no Power Pivot. Se você nomear a tabela que você criar no Power Pivot Date, precisará incluir o nome da tabela com aspas individuais em qualquer fórmula DAX que a referencie em um argumento. Todas as imagens e fórmulas de exemplo neste artigo referem-se a uma tabela de datas criada no Power Pivot chamada Calendar.

Agora você tem uma tabela de datas no modelo de dados. Você pode adicionar novas colunas de data, como Ano, Mês etc. usando DAX.

Adicionando novas colunas de data à tabela de datas

Uma tabela de datas com uma única coluna de data que tem uma linha para cada dia para cada ano é importante para definir todas as datas em um intervalo de datas. Também é necessário para criar uma relação entre a tabela de fatos e a tabela de datas. Mas essa coluna de data única com uma linha para cada dia não é útil ao analisar por datas em um relatório da Tabela Dinâmica ou do Power View. Você deseja que sua tabela de datas inclua colunas que ajudam a agregar seus dados para um intervalo ou grupo de datas. Por exemplo, você pode querer somar valores de vendas por mês ou trimestre ou pode criar uma medida que calcula o crescimento ano a ano. Em cada um desses casos, sua tabela de datas precisa de colunas ano, mês ou trimestre que permitem agregar seus dados para esse período.

Se você importou sua tabela de data de uma fonte de dados relacional, ela já poderá incluir os diferentes tipos de colunas de data desejadas. Em alguns casos, talvez você queira modificar algumas dessas colunas ou criar colunas de data adicionais. Isso é especialmente verdadeiro se você criar sua própria tabela de datas no Excel e copiá-la no Modelo de Dados. Felizmente, criar novas colunas de data no Power Pivot é muito fácil com funções de data e hora no DAX.

Dica: Se você ainda não trabalhou com o DAX, um ótimo lugar para começar a aprender é com o QuickStart: Aprenda o DAX Basics em 30 Minutos em Office.com.

Funções de data e hora do DAX

Se você já trabalhou com funções de data e hora em fórmulas do Excel, provavelmente estará familiarizado com as Funções de Data e Hora. Embora essas funções sejam semelhantes aos seus equivalentes no Excel, há algumas diferenças importantes:

  • As funções DAX Date e Time usam um tipo de dados datetime.

  • Eles podem usar valores de uma coluna como um argumento.

  • Eles podem ser usados para retornar e/ou manipular valores de data.

Essas funções geralmente são usadas ao criar colunas de data personalizadas em uma tabela de datas, portanto, elas são importantes para entender. Usaremos várias dessas funções para criar colunas para Ano, Trimestre, FiscalMonth e assim por diante.

Observação: As funções Date e Time no DAX não são iguais às funções de Time Intelligence. Saiba mais sobre o Time Intelligence no Power Pivot no Excel 2013.

O DAX inclui as seguintes funções data e hora:

Há muitas outras funções DAX que você pode usar em suas fórmulas também. Por exemplo, muitas das fórmulas descritas aqui usam Funções Matemáticas e Trigonométricas como MOD e TRUNC, Funções Lógicas como IF e Funções de Texto como FORMAT Para obter mais informações sobre outras funções DAX, consulte a seção Recursos Adicionais mais adiante neste artigo.

Exemplos de fórmula para um ano civil

Os exemplos a seguir descrevem fórmulas usadas para criar colunas adicionais em uma tabela de datas chamada Calendário. Uma coluna, chamada Date, já existe e contém um intervalo contíguo de datas de 1/1/2010 a 31/12/2016.

Ano

=YEAR([date])

Nesta fórmula, a função YEAR retorna o ano do valor na coluna Data. Como o valor na coluna Data é do tipo de dados datetime, a função YEAR sabe como retornar o ano dela.

Coluna do ano

Mês

=MONTH([date])

Nesta fórmula, assim como na função YEAR, podemos simplesmente usar a função MONTH para retornar um valor mensal da coluna Data.

Coluna do mês

Trimestre

=INT(([Month]+2)/3)

Nesta fórmula, usamos a função INT para retornar um valor de data como inteiro. O argumento que especificamos para a função INT é o valor da coluna Mês, adicione 2 e divida-o por 3 para obter nosso trimestre, 1 a 4.

Coluna do trimestre

Mês Nome

=FORMAT([date],"mmmm")

Nesta fórmula, para obter o nome do mês, usamos a função FORMAT para converter um valor numérico da coluna Data em texto. Especificamos a coluna Date como o primeiro argumento e, em seguida, o formato; queremos que nosso nome de mês mostre todos os caracteres, portanto, usamos "mmmm". Nosso resultado se parece com este:

Coluna de nome do mês

Se quisermos retornar o nome do mês abreviado para três letras, usaremos "mmm" no argumento de formato.

Dia da semana

=FORMAT([date],"ddd")

Nesta fórmula, usamos a função FORMAT para obter o nome do dia. Como só queremos um nome de dia abreviado, especificamos "ddd" no argumento de formato.

Coluna do dia da semana
Exemplo de Tabela Dinâmica

Depois de ter campos para datas como Ano, Trimestre, Mês etc., você pode usá-los em uma Tabela Dinâmica ou relatório. Por exemplo, a imagem a seguir mostra o campo SalesAmount da tabela De fatos de vendas em VALUES e Ano e Trimestre da tabela de dimensões calendário em ROWS. SalesAmount é agregado para o contexto ano e trimestre.

Exemplo de Tabela Dinâmica

Exemplos de fórmula para um ano fiscal

Fiscal Year

=IF([Mês]<= 6,[Ano],[Ano]+1)

Neste exemplo, o ano fiscal começa em 1º de julho.

Não há nenhuma função que possa extrair um ano fiscal de um valor de data porque as datas de início e término de um ano fiscal são muitas vezes diferentes das de um ano civil. Para obter o ano fiscal, primeiro usamos uma função IF para testar se o valor de Mês é menor ou igual a 6. No segundo argumento, se o valor de Mês for menor ou igual a 6, retornará o valor da coluna Ano. Caso contrário, retorne o valor de Ano e adicione 1.

Coluna de ano fiscal

Outra maneira de especificar um valor do mês de fim de ano fiscal é criar uma medida que simplesmente especifica o mês. Por exemplo, FYE:=6. Em seguida, você pode referenciar o nome da medida no lugar do número do mês. Por exemplo, =IF([Month]<=[FYE],[Year],[Year]+1). Isso fornece mais flexibilidade ao referenciar o mês de final do ano fiscal em várias fórmulas diferentes.

Mês Fiscal

=IF([Mês]<= 6, 6+[Mês], [Mês]- 6)

Nesta fórmula, especificamos se o valor de [Mês] é menor ou igual a 6, em seguida, tomamos 6 e adicionamos o valor de Mês, caso contrário, subtraimos 6 do valor de [Mês].

Coluna de mês fiscal

Fiscal Quarter

=INT(([FiscalMonth]+2)/3)

A fórmula que usamos para FiscalQuarter é a mesma do trimestre em nosso ano civil. A única diferença é que especificamos [FiscalMonth] em vez de [Mês].

Coluna de trimestre fiscal

Feriados ou datas especiais

Você pode querer incluir uma coluna de data que indica que determinadas datas são feriados ou alguma outra data especial. Por exemplo, você pode querer somar totais de vendas para o Dia de Ano Novo adicionando um campo Holiday a uma Tabela Dinâmica, como uma segmentação ou filtro. Em outros casos, você pode querer excluir essas datas de outras colunas de data ou em uma medida.

Incluir feriados ou dias especiais é bastante simples. Você pode criar uma tabela no Excel que tenha as datas que deseja incluir. Em seguida, você pode copiar ou usar Adicionar ao Modelo de Dados para adicioná-lo ao Modelo de Dados como uma tabela vinculada. Na maioria dos casos, não é necessário criar uma relação entre a tabela e a tabela Calendário. Todas as fórmulas que fazem referência a ela podem usar a função LOOKUPVALUE para retornar valores.

Veja abaixo um exemplo de uma tabela criada no Excel que inclui feriados a serem adicionados à tabela de datas:

Data

Feriado

1/1/2010

Anos Novos

11/25/2010

Thanksgiving

12/25/2010

Natal

01.01.11

Anos Novos

11/24/2011

Thanksgiving

12/25/2011

Natal

01.01.12

Anos Novos

22.11.12

Thanksgiving

12/25/2012

Natal

1/1/2013

Anos Novos

11/28/2013

Thanksgiving

12/25/2013

Natal

11/27/2014

Thanksgiving

12/25/2014

Natal

01/01/2014

Anos Novos

11/27/2014

Thanksgiving

12/25/2014

Natal

1/1/2015

Anos Novos

11/26/2014

Thanksgiving

12/25/2015

Natal

01.01.16

Anos Novos

11/24/2016

Thanksgiving

12/25/2016

Natal

Na tabela de datas, criamos uma coluna chamada Holiday e usamos uma fórmula como esta:

=LOOKUPVALUE(Feriados[Feriado],Feriados[data],Calendário[data])

Vamos examinar essa fórmula com mais cuidado.

Usamos a função LOOKUPVALUE para obter valores da coluna Holiday na tabela Feriados. No primeiro argumento, especificamos a coluna em que nosso valor de resultado será. Especificamos a coluna Holiday na tabela Feriados porque esse é o valor que queremos que seja retornado.

=LOOKUPVALUE(Feriados[Feriado],Feriados[data],Calendário[data])

Em seguida, especificamos o segundo argumento, a coluna de pesquisa que tem as datas que desejamos pesquisar. Especificamos a coluna Data na tabela Feriados , assim:

=LOOKUPVALUE(Feriados[Feriado],Feriados[data],Calendário[data])

Por fim, especificamos a coluna em nossa tabela Calendário que tem as datas que desejamos pesquisar na tabela Feriado . É claro que esta é a coluna Data na tabela Calendário .

=LOOKUPVALUE(Feriados[Feriado],Feriados[data],Calendário[data])

A coluna Holiday retornará o nome do feriado para cada linha que tenha um valor de data que corresponda a uma data na tabela Feriados.

Tabela Feriado

Calendário personalizado – treze períodos de quatro semanas

Algumas organizações, como varejo ou serviço de alimentação, geralmente relatam períodos diferentes, como treze períodos de quatro semanas. Com um calendário de treze quatro semanas, cada período é de 28 dias; Portanto, cada período contém quatro segundas- feiras, quatro terças-feiras, quatro quartas-feiras e assim por diante. Cada período contém o mesmo número de dias e, normalmente, os feriados cairão no mesmo período a cada ano. Você pode optar por iniciar um período em qualquer dia da semana. Assim como acontece com datas em um calendário ou ano fiscal, você pode usar o DAX para criar colunas adicionais com datas personalizadas.

Nos exemplos abaixo, o primeiro período completo começa no primeiro domingo do ano fiscal. Nesse caso, o ano fiscal começa em 7/1.

Semana

Esse valor nos dá o número da semana começando com a primeira semana completa do ano fiscal. Neste exemplo, a primeira semana completa começa no domingo, portanto, a primeira semana completa no primeiro ano fiscal na tabela Calendário realmente começa em 7/4/2010 e continua até a última semana completa na tabela Calendário. Embora esse valor em si não seja tão útil na análise, é necessário calcular para uso em outras fórmulas de período de 28 dias.

=INT([date]-40356)/7)

Vamos examinar essa fórmula com mais cuidado.

Primeiro, criamos uma fórmula que retorna valores da coluna Data como um inteiro, assim:

=INT([date])

Em seguida, queremos procurar o primeiro domingo no primeiro ano fiscal. Vemos que é 7/4/2010.

Coluna da semana

Agora, subtraia 40356 (que é o inteiro para 27/06/2010, o último domingo do ano fiscal anterior) desse valor para obter o número de dias desde o início dos dias em nossa tabela Calendário, assim:

=INT([date]-40356)

Em seguida, divida o resultado por 7 (dias em uma semana), assim:

=INT(([date]-40356)/7)

O resultado se parece com este:

Coluna da semana

Período

O período neste calendário personalizado contém 28 dias e sempre começará em um domingo. Esta coluna retornará o número do período começando com o primeiro domingo no primeiro ano fiscal.

=INT(([Semana]+3)/4)

Vamos examinar essa fórmula com mais cuidado.

Primeiro, criamos uma fórmula que retorna um valor da coluna Semana como um inteiro, assim:

=INT([Semana])

Em seguida, adicione 3 a esse valor, assim:

=INT([Semana]+3)

Em seguida, divida o resultado por 4, assim:

=INT(([Semana]+3)/4)

O resultado se parece com este:

Coluna Período

Ano Fiscal do Período

Esse valor retorna o ano fiscal por um período.

=INT(([Period]+12)/13)+2008

Vamos examinar essa fórmula com mais cuidado.

Primeiro, criamos uma fórmula que retorna um valor de Period e adiciona 12:

= ([Period]+12)

Dividimos o resultado por 13, porque há treze períodos de 28 dias no ano fiscal:

=(([Period]+12)/13)

Adicionamos 2010, porque esse é o primeiro ano na tabela:

=(([Period]+12)/13)+2010

Por fim, usamos a função INT para remover qualquer fração do resultado e retornar um número inteiro, quando dividido por 13, assim:

=INT(([Period]+12)/13)+2010

O resultado se parece com este:

Coluna Ano Fiscal do período

Período no Ano Fiscal

Esse valor retorna o número do período, 1 a 13, começando com o primeiro Período completo (começando no domingo) em cada ano fiscal.

=IF(MOD([Period],13), MOD([Period],13),13)

Essa fórmula é um pouco mais complexa, por isso vamos descrevê-la primeiro em uma linguagem que entendemos melhor. Essa fórmula afirma, divida o valor de [Período] por 13 para obter um número de período (1-13) no ano. Se esse número for 0, retorne 13.

Primeiro, criamos uma fórmula que retorna o restante do valor de Period por 13. Podemos usar o MOD (funções Matemática e Trigonométrica) assim:

=MOD([Period],13)

Isso, na maioria das vezes, nos dá o resultado que queremos, exceto onde o valor para Period é 0 porque essas datas não se enquadram no primeiro ano fiscal, como nos primeiros cinco dias da nossa tabela de data de calendário de exemplo. Podemos cuidar disso com uma função IF. Caso nosso resultado seja 0, retornaremos 13, assim:

=IF(MOD([Period],13),MOD([Period],13),13)

O resultado se parece com este:

Coluna Período em Ano Fiscal

Exemplo de Tabela Dinâmica

A imagem abaixo mostra uma Tabela Dinâmica com o campo SalesAmount da tabela De fatos de vendas em VALUES e campos PeriodFiscalYear e PeriodInFiscalYear da tabela de dimensão de data calendário em ROWS. SalesAmount é agregado para o contexto por ano fiscal e período de 28 dias no ano fiscal.

Exemplo de Tabela Dinâmica para o ano fiscal

Relações

Depois de criar uma tabela de datas em seu Modelo de Dados, para começar a navegar seus dados em Tabelas Dinâmicas e relatórios e agregar dados com base nas colunas na tabela de dimensão de data, você precisa criar uma relação entre a tabela de fatos com os dados de transação e a tabela de data.

Como você precisa criar uma relação com base em datas, você vai querer ter certeza de criar essa relação entre colunas cujos valores são do tipo de dados datetime (Date).

Para cada valor de data na tabela de fatos, a coluna de pesquisa relacionada na tabela de datas deve conter valores correspondentes. Por exemplo, uma linha (registro de transação) na tabela de fatos Sales com um valor de 15/08/2012 12:00 na coluna DateKey deve ter um valor correspondente na coluna Data relacionada na tabela data (chamada Calendário). Essa é uma das razões mais importantes pelas quais você deseja que sua coluna de data na tabela de datas contenha um intervalo contíguo de datas que inclua qualquer data possível em sua tabela de fatos.

Criar relações no Modo de Exibição de Diagrama

Observação: Embora a coluna de data em cada tabela deva ser do mesmo tipo de dados (Data), o formato de cada coluna não importa..

Observação: Se o Power Pivot não permitir que você crie relações entre as duas tabelas, os campos de data podem não armazenar a data e a hora no mesmo nível de precisão. Dependendo da formatação da coluna, os valores podem ser iguais, mas armazenados de forma diferente. Leia mais sobre como trabalhar com o tempo.

Observação: Evite usar chaves substitutas inteiros em relacionamentos. Quando você importa dados de uma fonte de dados relacional, muitas vezes as colunas de data e hora são representadas por uma chave substituta, que é uma coluna inteiro usada para representar uma data exclusiva. No Power Pivot, você deve evitar criar relações usando chaves de data/hora inteiros e, em vez disso, usar colunas que contenham valores exclusivos com um tipo de dados de data. Embora o uso de chaves substitutas seja considerado uma prática recomendada em data warehouses tradicionais, as chaves inteiros não são necessárias no Power Pivot e podem dificultar o agrupamento de valores em Tabelas Dinâmicas por períodos de data diferentes.

Se você receber um erro de incompatibilidade de tipo ao tentar criar uma relação, é provável porque a coluna na tabela de fatos não é do tipo de dados Date. Isso pode acontecer quando o Power Pivot não pode converter automaticamente uma não data (geralmente um tipo de dados de texto) em um tipo de dados de data. Você ainda pode usar a coluna na tabela de fatos, mas precisará converter os dados com uma fórmula DAX em uma nova coluna calculada. Consulte Converter datas de tipo de dados de texto em um tipo de dados de data posterior no apêndice.

Várias relações

Em alguns casos, pode ser necessário criar várias relações ou criar várias tabelas de datas. Por exemplo, se houver vários campos de data na tabela De fatos de Vendas, como DateKey, ShipDate e ReturnDate, todos eles poderão ter relações com o campo Date na tabela Data, mas apenas um deles pode ser uma relação ativa. Nesse caso, como DateKey representa a data da transação e, portanto, a data mais importante, isso serviria melhor como a relação ativa . Os outros têm relações inativas.

A Tabela Dinâmica a seguir calcula o total de vendas por Ano Fiscal e Trimestre Fiscal. Uma medida denominada Vendas Totais, com a fórmula Total Sales:=SUM([SalesAmount]), é colocada em VALORES, e os campos FiscalYear e FiscalQuarter da tabela de datas calendário são colocados em LINHAS.

Tabela dinâmica do total de vendas por trimestre fiscal Lista de Campo da Tabela Dinâmica

Essa Tabela Dinâmica direta funciona corretamente porque queremos somar nossas vendas totais até a data da transação no DateKey. Nossa medida Vendas Totais usa as datas no DateKey e é resumida por ano fiscal e trimestre fiscal porque há uma relação entre DateKey na tabela Vendas e a coluna Data na tabela de datas calendário.

Relações inativas

Mas, e se quiséssemos resumir nossas vendas totais não por data de transação, mas por data de envio? Precisamos de uma relação entre a coluna ShipDate na tabela Vendas e a coluna Data na tabela Calendário. Se não criarmos essa relação, nossas agregações serão sempre baseadas na data da transação. No entanto, podemos ter várias relações, embora apenas uma possa estar ativa e, como a data da transação é a mais importante, ela obtém a relação ativa com a tabela Calendário.

Nesse caso, o ShipDate tem uma relação inativa, portanto, qualquer fórmula de medida criada para agregar dados com base em datas de navio deve especificar a relação inativa usando a função USERELATIONSHIP .

Por exemplo, como há uma relação inativa entre a coluna ShipDate na tabela Vendas e a coluna Data na tabela Calendário, podemos criar uma medida que soma o total de vendas por data de envio. Usamos uma fórmula como esta para especificar a relação a ser usada:

Vendas totais por data do navio:=CALCULATE(SUM(Sales[SalesAmount]), USERELATIONSHIP(Sales[ShipDate], Calendar[Date]))

Essa fórmula simplesmente afirma: calcular uma soma para SalesAmount, mas filtrar usando a relação entre a coluna ShipDate na tabela Vendas e a coluna Data na tabela Calendário.

Agora, se criarmos uma Tabela Dinâmica e colocarmos a medida Total de Vendas por Data de Navio em VALORES e Ano Fiscal e Trimestre Fiscal em LINHAS, veremos o mesmo Grande Total, mas todos os outros valores de soma para o ano fiscal e o trimestre fiscal são diferentes porque são baseados na data do navio e não na data da transação.

Tabela dinâmica de vendas totais por data de envio Lista de Campo da Tabela Dinâmica

O uso de relações inativas permite que você use apenas uma tabela de datas, mas exige que todas as medidas (como Total de Vendas por Data de Navio), referenciem a relação inativa em sua fórmula. Há outra alternativa, ou seja, usar várias tabelas de datas.

Várias tabelas de datas

Outra maneira de trabalhar com várias colunas de data na tabela de fatos é criar várias tabelas de datas e criar relações ativas separadas entre elas. Vamos examinar nosso exemplo de tabela de vendas novamente. Temos três colunas com datas em que talvez queiramos agregar dados:

  • Um DateKey com a data de venda para cada transação.

  • Um ShipDate – com a data e a hora em que os itens vendidos foram enviados para o cliente.

  • Um ReturnDate – com a data e a hora em que um ou mais itens retornados foram recebidos.

Lembre-se de que o campo DateKey com a data da transação é mais importante. Faremos a maioria de nossas agregações com base nessas datas, portanto, certamente queremos uma relação entre ela e a coluna Data na tabela Calendário. Se não quisermos criar relações inativas entre ShipDate e ReturnDate e o campo Data na tabela Calendário, exigindo assim fórmulas de medidas especiais, podemos criar tabelas de datas adicionais para data de envio e data de retorno. Em seguida, podemos criar relações ativas entre eles.

Relações com várias tabelas de data no Modo de Exibição de Diagrama

Neste exemplo, criamos outra tabela de datas chamada ShipCalendar. Isso, é claro, também significa criar colunas de datas adicionais e, como essas colunas de data estão em uma tabela de datas diferente, queremos nomeá-las de maneira que as diferencie das mesmas colunas na tabela Calendário. Por exemplo, criamos colunas chamadas ShipYear, ShipMonth, ShipQuarter e assim por diante.

Se criarmos nossa Tabela Dinâmica e colocarmos nossa medida de Vendas Totais em VALUES e ShipFiscalYear e ShipFiscalQuarter em LINHAS, veremos os mesmos resultados que vimos quando criamos uma relação inativa e um campo calculado total de Vendas por Data de Navio especial.

Tabela dinâmica de vendas totais por data de envio com calendário de envio lista de campos de tabela dinâmica

Cada uma dessas abordagens requer uma consideração cuidadosa. Ao usar várias relações com uma única tabela de datas, talvez seja necessário criar medidas especiais que transitem em relações inativas usando a função USERELATIONSHIP. Por outro lado, criar várias tabelas de datas pode ser confuso em uma Lista de Campos e, como você tem mais tabelas no Modelo de Dados, isso exigirá mais memória. Experimente o que funciona melhor para você.

Propriedade Date Table

A propriedade Tabela de Data define metadados necessários para que funções Time-Intelligence como TOTALYTD, PREVIOUSMONTH e DATESBETWEEN funcionem corretamente. Quando um cálculo é executado usando uma dessas funções, o mecanismo de fórmula do Power Pivot sabe para onde ir para obter as datas necessárias.

Aviso: Se essa propriedade não estiver definida, as medidas usando o DAX Time-Intelligence funções poderão não retornar resultados corretos.

Ao definir a propriedade Date Table, você especifica uma tabela de datas e uma coluna de data do tipo de dados Date (datetime) nela.

Caixa de diálogo Marcar Como Tabela de Data

Como definir a propriedade Tabela de Data

  1. Na janela PowerPivot, selecione a tabela Calendário .

  2. Na guia Design , clique em Marcar como tabela de datas.

  3. Na caixa de diálogo Marcar como Tabela de Data, selecione uma coluna com valores exclusivos e o tipo de dados Date.

Trabalhando com o tempo

Todos os valores de data com um tipo de dados Date no Excel ou SQL Server são na verdade um número. Incluídos nesse número estão dígitos que se referem a uma hora. Em muitos casos, essa hora para cada linha é meia-noite. Por exemplo, se um campo DateTimeKey em uma tabela de fatos de Vendas tiver valores como 19/10/2010 12:00:00 am, isso significa que os valores estão no nível diurno de precisão. Se os valores de campo DateTimeKey tiverem um tempo incluído, por exemplo, 19/10/2010 8:44:00 AM, isso significa que os valores estão no nível de precisão de minuto. Os valores também podem ser para a precisão do nível da hora ou até mesmo para o nível de precisão de segundos. O nível de precisão no valor de tempo terá um impacto significativo na forma como você cria sua tabela de datas e as relações entre ela e sua tabela de fatos.

Você precisa determinar se você agregará seus dados a um nível diário de precisão ou a um nível de tempo de precisão. Em outras palavras, talvez você queira usar colunas em sua tabela de datas, como campos de data da manhã, tarde ou hora como data de hora em áreas de Linha, Coluna ou Filtro de Tabela Dinâmica.

Observação: Os dias são a menor unidade de tempo com a qual as funções do DAX Time Intelligence podem funcionar. Se você não precisar trabalhar com valores de tempo, deverá reduzir a precisão de seus dados para usar dias como a unidade mínima.

Se você pretende agregar seus dados ao nível de hora, sua tabela de datas precisará de uma coluna de data com a hora incluída. Na verdade, ele precisará de uma coluna de data com uma linha para cada hora, ou talvez até mesmo a cada minuto, de cada dia, para cada ano no intervalo de datas. Isso ocorre porque, para criar uma relação entre a coluna DateTimeKey na tabela de fatos e a coluna de data na tabela de datas, você deve ter valores correspondentes. Como você pode imaginar, se você incluir muitos anos, isso pode fazer uma tabela de datas muito grande.

Na maioria dos casos, porém, você deseja agregar seus dados apenas ao dia. Em outras palavras, você usará colunas como Ano, Mês, Semana ou Dia da Semana como campos em áreas de Linha, Coluna ou Filtro de Tabela Dinâmica. Nesse caso, a coluna de data na tabela de datas precisa conter apenas uma linha para cada dia em um ano, como descrevemos anteriormente.

Se sua coluna de data incluir um nível de tempo de precisão, mas você agregará apenas a um nível de dia, para criar a relação entre a tabela de fatos e a tabela de data, talvez seja necessário modificar sua tabela de fatos criando uma nova coluna que trunque os valores na coluna de data para um valor diário. Em outras palavras, converta um valor como 19/10/2010 8:44:00para19/10/2010 12:00:00. Em seguida, você pode criar a relação entre essa nova coluna e a coluna de data na tabela de datas porque os valores correspondem.

Vamos ver um exemplo. Esta imagem mostra uma coluna DateTimeKey na tabela De fatos de Vendas. Todas as agregações para os dados nesta tabela só precisam ser para o nível do dia, usando colunas na tabela de datas calendário como Ano, Mês, Trimestre etc. A hora incluída no valor não é relevante, apenas a data real.

Coluna DateTimeKey

Como não precisamos analisar esses dados para o nível de tempo, não precisamos da coluna Data na tabela de datas calendário para incluir uma linha para cada hora e cada minuto de cada dia em cada ano. Portanto, a coluna Data em nossa tabela de datas tem a seguinte aparência:

Coluna de data no Power Pivot

Para criar uma relação entre a coluna DateTimeKey na tabela Vendas e a coluna Data na tabela Calendário, podemos criar uma nova coluna calculada na tabela de fatos Vendas e usar a função TRUNC para truncar o valor de data e hora na coluna DateTimeKey em um valor de data que corresponda aos valores na coluna Data na tabela Calendário. Nossa fórmula se parece com esta:

=TRUNC([DateTimeKey],0)

Isso nos dá uma nova coluna (chamamos DateKey) com a data da coluna DateTimeKey e uma hora das 12:00:00 para cada linha:

Coluna DateKey

Agora podemos criar uma relação entre essa nova coluna (DateKey) e a coluna Data na tabela Calendário.

Da mesma forma, podemos criar uma coluna calculada na tabela Vendas que reduz a precisão de tempo na coluna DateTimeKey para o nível de hora de precisão. Nesse caso, a função TRUNC não funcionará, mas ainda podemos usar outras funções DAX Date e Time para extrair e recontentar um novo valor para um nível de hora de precisão. Podemos usar uma fórmula como esta:

= DATE (YEAR([DateTimeKey]), MONTH([DateTimeKey]), DAY([DateTimeKey]) ) + TIME (HOUR([DateTimeKey]), 0, 0)

Nossa nova coluna se parece com esta:

Coluna DateTimeKey

Desde que nossa coluna Date na tabela de datas tenha valores para o nível de hora de precisão, podemos criar uma relação entre eles.

Tornando as datas mais utilizáveis

Muitas das colunas de data que você cria na tabela de datas são necessárias para outros campos, mas realmente não são tão úteis na análise. Por exemplo, o campo DateKey na tabela Vendas a que nos referimos e mostramos ao longo deste artigo é importante porque, para cada transação, essa transação é registrada como ocorrendo em uma data e hora específicas. Mas, do ponto de vista de análise e relatório, não é tão útil porque não podemos usá-lo como um campo de linha, coluna ou filtro em uma Tabela Dinâmica ou relatório.

Da mesma forma, em nosso exemplo, a coluna Data na tabela Calendário é muito útil, de fato crítica, mas você não pode usá-la como uma dimensão em uma Tabela Dinâmica.

Para manter as tabelas e as colunas nelas o mais úteis possível e tornar as listas de relatórios de Tabela Dinâmica ou do Power View mais fáceis de navegar, é importante ocultar colunas desnecessárias das ferramentas do cliente. Você também pode querer ocultar determinadas tabelas também. A tabela Feriados mostrada anteriormente contém datas de feriado que são importantes para determinadas colunas na tabela Calendário, mas você não pode usar as colunas Data e Feriado na tabela Feriados em si como campos em uma Tabela Dinâmica. Aqui novamente, para tornar o Campo Listas mais fácil de navegar, você pode ocultar toda a tabela Feriados.

Outro aspecto importante do trabalho com datas são as convenções de nomenclatura. Você pode nomear tabelas e colunas no Power Pivot o que quiser. Mas tenha em mente, especialmente se você compartilhar sua pasta de trabalho com outros usuários, uma boa convenção de nomenclatura facilita a identificação de tabelas e datas, não apenas no Field Listas, mas também no Power Pivot e nas fórmulas DAX.

Depois de ter uma tabela de datas em seu Modelo de Dados, você pode começar a criar medidas que ajudarão você a aproveitar ao máximo seus dados. Alguns podem ser tão simples quanto resumir totais de vendas para o ano atual, e outros podem ser mais complexos, onde você precisa filtrar em um determinado intervalo de datas exclusivas. Saiba mais em Medidas em Funções de Power Pivot e Time Intelligence.

Apêndice

Converter datas de tipo de dados de texto em um tipo de dados de data

Em alguns casos, uma tabela de fatos com dados de transação pode conter datas do tipo de dados de texto. Ou seja, uma data que aparece como 2012-12-04T11:47:09 não é de fato uma data, ou pelo menos não o tipo de data que o Power Pivot pode entender. É realmente apenas um texto que lê como um encontro. Para criar uma relação entre uma coluna de data na tabela de fatos e uma coluna de data em uma tabela de datas, ambas as colunas devem ser do tipo de dados Date .

Normalmente, quando você tenta alterar o tipo de dados para uma coluna de datas que são tipo de dados de texto para um tipo de dados de data, o Power Pivot pode interpretar as datas e convertê-la em um tipo de dados de data real automaticamente. Se o Power Pivot não puder fazer uma conversão de tipo de dados, você receberá um erro de incompatibilidade de tipo.

No entanto, você ainda pode converter as datas em um tipo de dados de data verdadeira. Você pode criar uma nova coluna calculada e usar uma fórmula DAX para analisar o ano, mês, dia, hora etc. das cadeias de caracteres de texto e, em seguida, concatená-la novamente de uma maneira que o Power Pivot possa ler como uma data verdadeira.

Neste exemplo, importamos uma tabela de fatos chamada Sales para o Power Pivot. Ele contém uma coluna chamada DateTime. Os valores aparecem assim:

Colunas DateTime em uma tabela de fatos.

Se examinarmos o Tipo de Dados na guia Página Inicial do Grupo de Formatação do Power Pivot, veremos que ele é tipo de dados de texto.

Tipo de dados na faixa de opções

Não é possível criar uma relação entre a coluna DateTime e a coluna Date em nossa tabela de datas porque os tipos de dados não correspondem. Se tentarmos alterar o tipo de dados para Date, teremos um erro de incompatibilidade de tipo:

Erro de incompatibilidade

Nesse caso, o Power Pivot não pôde converter o tipo de dados de texto em data. Ainda podemos usar esta coluna, mas para obtê-la em um tipo de dados de data verdadeira, precisamos criar uma nova coluna que analise o texto e o recria em um valor que o Power Pivot possa criar um tipo de dados Date.

Lembre-se, da seção Trabalhar com tempo anterior neste artigo; a menos que seja necessário que sua análise seja para um nível de precisão de hora do dia, você deve converter datas em sua tabela de fatos em um nível diário de precisão. Com isso em mente, queremos que os valores em nossa nova coluna estejam no nível diurno de precisão (excluindo a hora). Podemos converter os valores na coluna DateTime em um tipo de dados de data e remover o nível de tempo de precisão com a seguinte fórmula:

=DATE(LEFT([DateTime],4), MID([DateTime],6,2), MID([DateTime],9,2))

Isso nos dá uma nova coluna (nesse caso, chamada Date). O Power Pivot até detecta os valores como datas e define o tipo de dados automaticamente como Date.

Coluna de data na tabela de fatos

Se quisermos preservar o nível de tempo de precisão, basta estender a fórmula para incluir as horas, minutos e segundos.

=DATE(LEFT([DateTime],4), MID([DateTime],6,2), MID([DateTime],9,2)) +

TIME(MID([DateTime],12,2), MID([DateTime],15,2), MID([DateTime],18,2))

Agora que temos uma coluna Date do tipo de dados Date, podemos criar uma relação entre ela e uma coluna de data em uma data.

Recursos adicionais

Datas no Power Pivot

Cálculos no Power Pivot

Início rápido: aprenda os fundamentos de DAX em 30 minutos

Referência de expressões de análise de dados

Centro de Recursos DAX

Precisa de mais ajuda?

Quer mais opções

Explore os benefícios da assinatura, procure cursos de treinamento, saiba como proteger seu dispositivo e muito mais.

As comunidades ajudam você a fazer e responder perguntas, fazer comentários e ouvir especialistas com conhecimento avançado.

Essas informações foram úteis?

Qual é o seu grau de satisfação com a qualidade do idioma?
O que afetou sua experiência?
Ao pressionar enviar, seus comentários serão usados para aprimorar os produtos e serviços da Microsoft. Seu administrador de TI poderá coletar esses dados. Política de Privacidade.

Agradecemos seus comentários!

×