Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Aplica-se a:
Coluna calculada
Tabela calculada
Medida
Cálculo visual
Observação
Esta função é desencorajada para uso em cálculos visuais pois provavelmente retorna resultados sem sentido.
Para entrada de coluna de data, retorna uma tabela que contém uma coluna de datas que começa com uma data de início especificada e continua até uma data de término especificada.
Para entrada de calendário, retorna uma tabela que começa com uma data de início especificada e continua até uma data de término especificada. A tabela contém todas as colunas marcadas primárias e todas as colunas relacionadas ao tempo.
Esta função é adequada para passar como um filtro para a função CALCULATE. Use-o para filtrar uma expressão por um intervalo de datas personalizado.
Observação
Se você estiver trabalhando com intervalos de data padrão, como dias, meses, trimestres ou anos, é recomendável usar a função DATESINPERIOD mais adequada.
Sintaxe
DATESBETWEEN(<dates> or <calendar>, <StartDate>, <EndDate>)
Parâmetros
| Vigência | Definição |
|---|---|
dates or calendar |
Uma coluna que contém datas ou uma referência de calendário |
StartDate |
Uma expressão de data/dia. Se a sintaxe do calendário for usada, use o mesmo tipo de dados da coluna principal marcada para a categoria Dia. |
EndDate |
Uma expressão de data/dia. Se a sintaxe do calendário for usada, use o mesmo tipo de dados da coluna principal marcada para a categoria Dia. |
Valor de retorno
Para entrada de coluna de data, uma tabela contendo uma única coluna de valores de data.
Para entrada de calendário, uma tabela que contém todas as colunas marcadas primárias e todas as colunas relacionadas ao tempo.
Comentários
No caso de uso mais comum,
datesé uma referência à coluna de data de uma tabela de data marcada.Se
StartDatefor BLANK, entãoStartDateserá o valor mais antigo na colunadates. Para calendário, será o primeiro valor na coluna marcado como dia.Se
EndDatefor BLANK,EndDateserá o valor mais recente na colunadates. Para calendário, será o último valor na coluna marcada como dia.As datas utilizadas como
StartDateeEndDateestão incluídas. Assim, por exemplo, se o valorStartDatefor 1 de julho de 2019, essa data será incluída na tabela devolvida (desde que a data exista na colunadates).Para entrada de coluna de data, a tabela retornada só pode conter datas armazenadas na
Datescoluna. Assim, por exemplo, se a colunaDatescomeçar a partir de 1º de julho de 2017 e o valorStartDatefor 1º de julho de 2016, a tabela retornada começará a partir de 1º de julho de 2017.Para a entrada de calendário, se a data de entrada não for encontrada na coluna de dia marcado, ela será tratada como BLANK e, portanto, o primeiro/último valor será usado.
Para a entrada de calendário, use o mesmo tipo de dados e formato que a coluna de dia marcado para a data de início e a data de término. Por exemplo, se a coluna usar o formato AAAA-Sn-Qn-Mnn-Wnn-Dnn (por exemplo, "2014-S2-Q4-M11-W45-D03"), a data de início e a data de término devem seguir o mesmo formato (por exemplo, "2015-S2-Q4-M11-W45-D03"). Caso contrário, o comportamento é indefinido.
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
A seguinte definição de medida de tabela de de vendas
Observe que a fórmula usa a função MAX. Esta função retorna a data mais recente que está no contexto do filtro. Assim, a função DATESBETWEEN retorna uma tabela de datas que começam desde a data mais antiga até a data mais recente que está sendo relatada.
Exemplos neste artigo podem ser usados com o modelo de exemplo do Power BI Desktop do Adventure Works DW 2020. Para obter o modelo, consulte DAX exemplo de modelo.
Customers LTD =
CALCULATE (
DISTINCTCOUNT ( Sales[CustomerKey] ),
DATESBETWEEN ( 'Date'[Date], BLANK (), MAX ( 'Date'[Date] ) )
)
Considere que a data mais antiga armazenada na tabela Data é 1º de julho de 2017. Assim, quando um relatório filtra a medida até o mês de junho de 2020, a função DATESBETWEEN retorna um intervalo de datas de 1º de julho de 2017 a 30 de junho de 2020.
Exemplo de inteligência de tempo baseada em calendário
A seguinte definição de medida de tabela de de vendas
Observe que a fórmula usa a função MAX. Essa função retorna a tecla de data máxima que está no contexto do filtro. Assim, a função DATESBETWEEN retorna uma tabela de datas que começam desde a data mais antiga até a data mais recente que está sendo relatada. DateKey é usado como um exemplo para mostrar que a categoria "Dia" pode ser marcada com uma coluna que não é digitada por data
Customers LTD =
CALCULATE (
DISTINCTCOUNT ( Sales[CustomerKey] ),
DATESBETWEEN ( FiscalCalendar, BLANK (), MAX ( 'Date'[DateKey] ) )
)