KEMBAR78
DAX Functions Quick Reference Guide | PDF | Trigonometric Functions | Sine
0% found this document useful (0 votes)
434 views47 pages

DAX Functions Quick Reference Guide

This document provides a quick reference guide for DAX functions. It contains a list of over 50 DAX functions organized into categories like aggregation, date/time, filter, logical, and more. Each function is accompanied by a brief description and notes on usage. The document is intended as a supplement to more detailed online documentation on DAX functions. It allows users to search for specific functions to learn their purpose and appropriate usage.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
434 views47 pages

DAX Functions Quick Reference Guide

This document provides a quick reference guide for DAX functions. It contains a list of over 50 DAX functions organized into categories like aggregation, date/time, filter, logical, and more. Each function is accompanied by a brief description and notes on usage. The document is intended as a supplement to more detailed online documentation on DAX functions. It allows users to search for specific functions to learn their purpose and appropriate usage.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 47

Last updated 14th March 2020 Version 3.

53
DAX Functions List
This DAX functions quick reference guide has been prepared by Matt Allington from
http://exceleratorbi.com.au and contains a list of all the current DAX functions in a summarised and easy to
use format. You can print the document and/or use the search features for PDF documents to search for
the function you are looking for.
This document is a supplement and is not intended to replace the more detailed documentation that is
available online.
When looking for online documentation it is best to do a web search from your favourite search engine by
specifying the function name followed by the word DAX i.e. “FunctionName DAX”.
Tip: If you are going to search this document for a function name using search, then type the function name
followed by an open bracket. E.g. instead of searching for VALUES you should search VALUES(.

Contents

DAX Aggregation Functions (Aggregators).............................................................................................. 3


DAX Date and Time Functions ................................................................................................................ 5
DAX Filter Functions ............................................................................................................................... 8
DAX Information Functions.................................................................................................................... 14
DAX Logical Functions .......................................................................................................................... 16
DAX Math and Trig Functions ............................................................................................................... 18
DAX Other Functions ............................................................................................................................ 23
DAX Other Special Functions (X-Functions / Iterators).......................................................................... 24
DAX Other Special Functions (Argument Functions) ............................................................................. 27
DAX Parent and Child Functions ........................................................................................................... 29
DAX Query Functions ............................................................................................................................ 30
DAX Statistical Functions ...................................................................................................................... 34
DAX Text Functions .............................................................................................................................. 37
DAX Time Intelligence Functions .......................................................................................................... 40
DAX Time Intelligence Functions that return Scalar Values ............................................................... 40
DAX Time Intelligence Functions that return both a Table and a Scalar ............................................ 41
DAX Time Intelligence Functions that return a Table of Dates ........................................................... 43

More Great Ways to Learn

Power BI Online Training Power Query Online Training Power BI Live Training Learn to Write DAX in Power BI Learn to Write DAX in Excel

https://goo.gl/KR1Yxy https://goo.gl/pJkubh https://goo.gl/U93eNZ http://bit.ly/2NHsewx http://bit.ly/scpbi

Last updated 14th March 2020 Version 3.53


DAX Aggregation Functions (Aggregators)
DAX Aggregation Functions (called aggregators for short) take a column or a table as the argument and
aggregate the values.
Function Notes
AVERAGE(column) Returns the average (arithmetic mean) of all the numbers in a
column in the current filter context.
This function is the equivalent of adding up the values in the
column and then dividing by the number of rows.
AVERAGEA(column) The AVERAGEA function takes a column and averages the
numbers in it, but also handles non-numeric data types according
to the following rules:
• Values that evaluates to TRUE count as 1.
• Values that evaluate to FALSE count as 0 (zero).
• Values that contain non-numeric text count as 0 (zero).
• Empty text ("") counts as 0 (zero).
COUNT(column) Counts numbers only in the current filter context.
COUNTA(column) Counts text values as well as numbers in the current filter context.
COUNTBLANK(column) Counts the number of blank cells in a column in the current filter
context.
COUNTROWS(table) The COUNTROWS function counts the number of rows in the
specified table, or in a table defined by an expression in the
current filter context.
DISTINCTCOUNT(column) Counts each value in a column once and only once in the current
filter context.
DISTINCTCOUNTNOBLANK(column) Counts the number of distinct values in a column.
Unlike DISTINCTCOUNT function, DISTINCTCOUNTNOBLANK
does not include the BLANK value.
MAX(column) The MAX function takes a column or two expressions that return
numeric values as argument(s) and returns the largest numeric
MAX(
value.
expression1,
Ignores logical values and text in the current filter context.
expression2
Can also find the MAX of a text column.
)
MAXA(column) Like MAX, however also considers Dates and Logical values,
such as TRUE and FALSE. Rows that evaluate to TRUE count
as 1; rows that evaluate to FALSE count as 0 (zero)
MIN(column) The MIN function takes a column or two expressions that return
numeric values as argument(s) and returns the smallest numeric
MIN(
value.
expression1,
Ignores logical values and text in the current filter context.
expression2
)

Last updated 14th March 2020 Version 3.53


Function Notes
MINA(column) Like MIN, however also considers Dates and Logical Values.
Rows that evaluate to TRUE count as 1; rows that evaluate to
FALSE count as 0 (zero)
PRODUCT(column) Multiplies all the values in a column together. Why you would
want to? I have no idea.
SUM(column) Adds all the numbers in a column in the current filter context.
TOPN( Returns a table containing the top N rows. Order by expression is
n_value, typically a measure that you want to rank on.
tablename,
orderByexpression1, [Order],
[orderByexpression2, [Order]], …
)

Last updated 14th March 2020 Version 3.53


DAX Date and Time Functions
You can use DAX Date and Time Functions in the calculations based on dates and time. DAX Date and
Time Functions are like the Excel date and time functions but use a datetime data type and can take values
from a column as an argument.
Function Notes
CALENDAR( Returns a table with a single column named “Date” that contains a
contiguous set of dates. The range of dates is from the specified
start date,
start date to the specified end date, inclusive of those two dates.
end date
)
CALENDARAUTO( Returns a table with a single column named “Date” that contains a
contiguous set of dates. The range of dates is calculated
[end month of fiscal year]
automatically based on data in the model.
)
DATE( Returns the specified date in datetime format.
year, • Dates beginning with March 1, 1900 are supported.
month, • If the year value is between 0 and 1899, the value is added to
1900 to produce the final value. The value of the year argument
day can include one to four digits.
) • You should use four digits for the year argument whenever
possible to prevent unwanted results.

DATEDIFF( Returns the count of interval boundaries crossed between two


dates.
start date,
The interval to use when comparing dates can be one of the
end date,
following:
interval
• SECOND
) • MINUTE
• HOUR
• DAY
• WEEK
• MONTH
• QUARTER
• YEAR
If start_date is larger than end_date an error is returned.
DATEVALUE(date text) Converts a date in the form of text to a date in datetime format.
DAY(date) Returns the day of the month, a number from 1 to 31.
EDATE( Returns the date that is the indicated number of months before or
after the start date.
start date,
You can use EDATE to calculate maturity dates or due dates that
months
fall on the same day of the month as the date of issue. You can
) also use EDATE to find the same date prior month or prior year.

Last updated 14th March 2020 Version 3.53


Function Notes
EOMONTH( Returns the date in datetime format of the last day of the month,
before or after a specified number of months.
start date,
You can use EOMONTH to calculate maturity dates or due dates
months
that fall on the last day of the month.
)
HOUR(datetime value) Returns the hour as a number from 0 (12:00 A.M.) to 23 (11:00
P.M.).
MINUTE(datetime value) Returns the minute as a number from 0 to 59, given a date and time
value.
MONTH(datetime value) Returns the month as a number from 1 (January) to 12 (December).
NOW() Returns the current date and time in datetime format.
The NOW function is useful when you need to display the current
date and time on a report or calculate a value based on the current
date and time, and have that value updated each time you open
the workbook.
QUARTER(datetime value) New in Power BI Desktop.
Returns the quarter as a number from 1 to 4.
1 (Jan – Mar) … 4 (Oct – Dec)
If the input value is BLANK, the output value is also BLANK.
SECOND(datetime value) Returns the seconds of a time value, as a number from 0 to 59.
TIME( Converts hours, minutes, and seconds given as numbers to a time
in datetime format.
hour,
minute,
second
)
TIMEVALUE(time text) Converts a time in text format to a time in datetime format.

TODAY() Returns the current date in datetime format.


The TODAY function is useful when you need to have the current
date displayed on a report. It is also useful for calculating intervals.
UTCNOW() Returns the current UTC date and time.
UTCTODAY() Returns the current UTC date.

Last updated 14th March 2020 Version 3.53


Function Notes
WEEKDAY( Returns a number from 1 to 7 identifying the day of the week of a
date.
date,
return type • If return type is 1, and the week begins on Sunday (1) and ends
on Saturday (7).
) • If return type is 2, the week begins on Monday (1) and ends on
Sunday (7).
• If return type is 3, the week begins on Monday (0) and ends on
Sunday (6).
WEEKNUM( Returns the week number for the given date in a year according to
the return_type value. The week number indicates where the week
date,
falls numerically within a year.
return type
If return type is 1, week begins on Sunday. Weekdays are
) numbered 1 through 7.
If return type is 2, week begins on Monday. Weekdays are
numbered 1 through 7.
YEAR(datetime value) Returns the year of a date as a four-digit integer in the range 1900-
9999.
YEARFRAC( Calculates the fraction of the year represented by the number of
whole days between two dates.
start_date,
Use the YEARFRAC function to identify the proportion of a whole
end_date,
year's benefits or obligations to assign to a specific term.
[basis]
Basis (optional) is the type of day count basis to use:
)
0 - US (NASD) 30/360
1 - Actual/actual
2 - Actual/360
3 - Actual/365
4 - European 30/360

Last updated 14th March 2020 Version 3.53


DAX Filter Functions
DAX Filter Functions are very different to Excel functions. They are used to (typically) return filtered tables
that can be used in your data model. These new “virtual” tables retain lineage with the physical data model
and hence they can “filter” the physical data model on the fly. Lookup functions work by using tables and
relationships between them. Filtering functions let you manipulate data context to create dynamic
calculations.
DAX FILTER and VALUES functions are the most complex and powerful functions.
Function Notes
1. Adds combinations of items from multiple columns
to a table if they do not already exist. The
ADDMISSINGITEMS(
determination of which item combinations to add
showAllColumn[, showAllColumn] …, is based on referencing source columns which
table, contain all the possible values for the columns.

groupingColumn[, groupingColumn] … To determine the combinations of items from


different columns to evaluate: AutoExist is
[, filterTable] … applied for columns within the same table while
) CrossJoin is applied across different tables.
2. The ADDMISSINGITEMS function will return
BLANK values for the IsSubtotal columns of
ADDMISSINGITEMS( blank rows it adds.
showAllColumn[, showAllColumn] …, See also: The argument functions –
table, ROLLUPISSUBTOTAL and ROLLUPGROUP.
[ROLLUPISSUBTOTAL(]
groupingColumn[, isSubtotal_columnName]
[, groupingColumn][, isSubtotal_columnName]

[)],
[, filterTable] …
)

Last updated 14th March 2020 Version 3.53


Function Notes
ALL( Updated in Power BI Desktop to include ALL().
[TableOrColumn] Returns all the rows in a table, or all the values in
a column, ignoring any filters that might have been
[, TableOrColumn] …
applied in the current context.
)
If Table is used as the argument, this function is
useful for clearing filters and creating calculations
on all the rows in a table.
If specific Columns are used as the arguments,
this function removes all filters from the specified
columns in the table and all other filters on other
columns in the table still apply.
This is useful when you want to remove the
context filters for one or more specific columns
and to keep all other context filters.
ALL() removes all the filters everywhere. ALL() can
only be used to clear filters but not to return a table.
ALLCROSSFILTERED(table) Clear all filters which are applied to a table.
ALLCROSSFILTERED can only be used to clear
filters but not to return a table.
ALLEXCEPT(
table, Removes all context filters in the table except
filters that are applied to the specified columns.
column
This is convenient to use when you want to
[, column] …
remove the filters on many, but not all, columns in
) a table.
ALLNOBLANKROW(table | column) When the passed parameter was a table, returns
all rows but the blank row from the parent table of
a relationship and disregards any context filters
that might exist.
When the passed parameter was a column,
returns all distinct values of the column but the
blank row, and disregards any context filters that
might exist.

Last updated 14th March 2020 Version 3.53


Function Notes
ALLSELECTED([tableName | columnName]) The ALLSELECTED function gets the context
that represents all rows and columns in the query,
while keeping explicit filters and contexts other
than row and column filters. This function can be
used to obtain visual totals in queries.
Keeps filters on Rows and Columns in a pivot
table while keeping the filters on slicers and other
explicit filters.
This function is different from ALL because it
retains all filters explicitly set within the query, and
it retains all context filters other than row and
column filters.
CALCULATE( Modifies the initial filter context prior to calculating
the expression. It can do this in 2 ways, by
expression
applying the new filters specified in the
[, filter1] CALCULATE function and/or by converting an
[, filter2] … existing row context into an equivalent filter
context aka context transition.
)
CALCULATETABLE( Modifies the filter context prior to returning a table
of values. It can do this in 2 ways, by applying the
expression,
new filters specified in the CALCULATETABLE
filter1, function and/or by converting an existing row
filter2, … context into an equivalent filter context aka
context transition.
)
CROSSFILTER( Sets the cross-filtering direction for the
indicated relationship, for the duration of the
columnName1,
query. It does not return any value.
columnName2,
You can use CROSSFILTER inside
direction CALCULATE.
) The cross-filter direction to be used is determined
by the argument – direction.
One - Filters on the one or lookup side of the side
of the relationship filter the many side.
Both - Filters on either side filter the other
None - No cross-filtering occurs along this
relationship
DISTINCT(column) Returns a 1 column table of all the distinct values
in the current filter context. If there are BLANKS
then they will be ignored. If you want to return a
BLANK as well, then use VALUES function
instead.

Last updated 14th March 2020 Version 3.53


Function Notes
DISTINCT(table) Returns a table by removing duplicate rows from
another table or expression.
The returned table will contain unique (or distinct)
rows.
EARLIER( Used to access a previous row context when more
than 1 row context exists in the function.
column
EARLIER is useful for nested calculations where
[, number]
you want to use a certain value as an input and
) produce calculations based on that input.
EARLIEST(column) As above, but returns the absolute first row
context.
FILTER( Returns a table containing only the filtered rows.
table, You can use FILTER to use only specific data in
calculations.
filter
FILTER is not used independently, but as a
)
function that is embedded in other functions such
as CALCULATE.
FILTERS(columnName) Returns a table containing the list of values that
are directly applied as filters.

HASONEFILTER(columnName) Returns TRUE when the number of directly


filtered values on columnName is one; otherwise
returns FALSE.
Used to check if there is one and only one filter on
a column in the current filter context.
HASONEVALUE(columnName) Returns TRUE when the context for columnName
has been filtered down to one distinct value only.
Otherwise is FALSE.
Used to check if there is one and only one value
visible in a column in the current filter context.
ISCROSSFILTERED(columnName) Returns TRUE when columnName or another
column in the same or related table is being
filtered. Otherwise returns FALSE.
Used to check if there is an indirect filter on a
column in the current filter context.
ISFILTERED(columnName) Returns TRUE when columnName is being
filtered directly. If there is no filter on the column
or if the filtering happens because a different
column in the same table or in a related table is
being filtered, then the function returns FALSE.
Used to check if there the column is filtered at all
in the current filter context.

Last updated 14th March 2020 Version 3.53


Function Notes
KEEPFILTERS(expression) You use KEEPFILTERS within the context
CALCULATE and CALCULATETABLE
functions, to override the standard behaviour of
those functions.
CALCULATE filters replace the current context,
while KEEPFILTERS adds filters to the current
context.
RELATED(column) Returns a related value from another table. A
single value that is related to the current row.
Forces a row context to follow the relationship to
a related table and return that value. Can only be
used on the many side of the relationship.
RELATEDTABLE(tableName) Returns a table of values from the many side of
the relationship.
Forces a row context to follow the relationship to
a related table and return that value. Can only be
used on the one side of the relationship.

REMOVEFILTERS( Clears filters from the specified table or columns.


[table | column[, column[, column[,…]]]]) REMOVEFILTERS can only be used to clear
filters but not to return a table.
So it can only be used within CALCULATE.
SELECTEDVALUE( It can be used as a substitute for
IF(HASONEVALUE()) and will return a scalar
columnName
value if there is one and only 1 value selected in
[, alternateResult] the current filter context.
) Otherwise returns alternateResult.
If alternateResult is omitted, the default value is
BLANK().

Last updated 14th March 2020 Version 3.53


Function Notes
SUBSTITUTEWITHINDEX( Returns a table which represents a left semijoin of
the two tables supplied as arguments. The
table,
semijoin is performed by using common columns,
indexColumnName, determined by common column names and
indexColumnsTable, common data type. The columns being joined on
are replaced with a single column in the returned
orderBy_expression[, order] table which is of type integer and contains an
[, orderBy_expression[, order]] … index. The index is a reference into the right join
table given a specified sort order.
)
Columns in the right/second table supplied which
do not exist in the left/first table supplied are not
included in the returned table and are not used to
join on.
The index starts at 0 (0-based) and is incremented
by one for each additional row in the right/second
join table supplied. The index is based on the sort
order specified for the right/second join table.

TREATAS( Returns a table that contains all the rows in


column(s) that are also in table_expression.
table_expression,
The number of columns specified must be equal
column1
to the number of columns in the table expression,
[, column2] and be in the same order.
[, column3] … Use when a relationship does not exist between
) the tables.

USERELATIONSHIP( You can have more than 1 relationship between 2


tables in DAX, but only 1 can be active at a time.
columnName1,
Use this function inside CALCULATE to use the
columnName2 inactive relationship instead of the active one.
)
VALUES(TableNameOrColumnName) Returns a table consisting of a single column of
unique values in the current filter context.
If there are blanks in the list a blank will be
returned.
If you want to exclude the blank then use
DISTINCT instead.

Last updated 14th March 2020 Version 3.53


DAX Information Functions
DAX Information Functions provide required information based on the given argument.
Function Notes
CONTAINS( Returns TRUE if each specified value is contained in the
corresponding columnName.Otherwise, the function returns
table,
FALSE.
columnName, value
[, columnName, value] …
)
CONTAINSROW( Returns TRUE if a row of values exists or contained in a table.
table, Otherwise returns FALSE.
scalar expression1 Note: The IN operator and the CONTAINSROW function are
functionally the same. Only the syntax is different.
[, scalar expression2, …]
)
CUSTOMDATA() Returns the content of the CustomData property in the
connection string.
Returns Blank, if CustomData property was not defined at
connection time.
scalar expression IN table IN Operator:
OR Returns TRUE if a row of values exists or contained in a table.
(scalar expression1, scalar expression2, Otherwise returns FALSE.
…) IN table
Note: The IN operator and the CONTAINSROW function are
functionally the same. Only the syntax is different.
ISBLANK(value) Returns TRUE if the value is blank.
Otherwise, returns FALSE.
ISEMPTY(table_expression) Returns TRUE if the table is empty (has no rows),
Returns FALSE otherwise.
ISERROR(value) Returns TRUE if the value is an Error.
Otherwise, returns FALSE.
ISEVEN(number) Returns TRUE if number is even,
Returns FALSE if number is odd.
If number is nonnumeric, ISEVEN returns the #VALUE! error
value.
ISINSCOPE(column) Returns TRUE when the specified column is the level in a
hierarchy of levels.

ISLOGICAL(value) Returns TRUE if the value is a logical value (TRUE OR


FALSE).
Otherwise, returns FALSE.

Last updated 14th March 2020 Version 3.53


Function Notes
ISNONTEXT(value) Returns TRUE if the value is not text or blank. (Blank cells are
not text).
Returns FALSE if the value is text.
An empty string is considered as text.
ISNUMBER(value) Returns TRUE if the value is numeric.
Otherwise, returns FALSE.
ISODD(number) Returns TRUE if number is odd.
Returns FALSE if number is even.
If number is nonnumeric, ISODD returns the #VALUE! error
value.
ISONORAFTER( This function takes a variable number of triples, the first two
parameters in a triple are the expressions to be compared and
scalar expression,
the third is the sort order - ascending (default) or descending.
scalar expression
Based on the sort order, the first parameter is compared with
[, sort order] the second parameter.
[, scalar expression, If the sort order is ascending, the comparison to be done is
scalar expression first parameter greater than or equal to second parameter.

[, sort order] If the sort order is descending, the comparison to be done is


first parameter less than or equal to second parameter
], …
)
ISTEXT(value) Returns TRUE if the value is text
Otherwise, returns FALSE.
Empty string is text.
Blank is not text.
LOOKUPVALUE( Updated in Power BI Desktop to include alternateResult.
result_columnName, Returns the value of result_column at the row where all pairs
of search_column and search_value have a match.
search_columnName,
If only some of the criteria match, a BLANK or alternateResult
search_value
(if given) is returned.
[, search_columnName,
If multiple rows match the search values and in all cases
search_value result_column values are identical, then that value is returned.
], … Otherwise, an error or alternateResult (if given) is returned.

[, <alternateResult>]
)
USERNAME() Returns the username from the credentials given to the system
at connection time. If this is a Power BI Desktop or Excel file
it will be in the format Domain\Username. If it is in the Power
BI Service, it will be in the format Username@domain.com

Last updated 14th March 2020 Version 3.53


DAX Logical Functions
DAX Logical Functions return values based on the conditional results.
Function Notes
AND( Checks whether both arguments are TRUE, and returns TRUE
if both arguments are TRUE. Otherwise returns FALSE.
logical_value,
If you have more than two arguments, use && (double
logical_value
ampersand) as an alternative and you can have as many “&&”
) as you like.
COALESCE( Returns the scalar value coming from the first expression that
expression, does not evaluate to BLANK. If all expressions evaluate to
BLANK, BLANK is returned.
expression
[, expression] … Input expressions may be of different data types that return a
scalar expression.
)
COALESCE can be used to convert BLANK values of totals
to 0.
COALESCE simplifies the code that otherwise requires an IF
condition.
i.e. instead of writing IF(ISBLANK(Result), 0, Result), we can
write COALESCE(Result, 0)
FALSE() Returns the logical value FALSE.
IF( Checks if a condition provided as the first argument is met.
Returns one value if the condition is TRUE and returns another
logical test,
value if the condition is FALSE.
value_if_true
Returns blank, if the condition is FALSE and value_if_false is
[, value_if_false] omitted.
)
IFERROR( Evaluates an expression and returns a specified value if the
expression returns an error. Otherwise, returns the value of
value,
the expression itself.
value_if_error
)
NOT(logical_value) Changes FALSE to TRUE, or TRUE to FALSE.
OR( Checks whether one of the arguments is TRUE to return
TRUE. The function returns FALSE if both arguments are
logical_value,
FALSE.
logical_value
If you have more than two arguments, use || (double pipe) as
) an alternative and you can have as many “||” as you like.

Last updated 14th March 2020 Version 3.53


Function Notes
SWITCH( Expression is evaluated and the result is matched with the
given values. If a match is found, the corresponding
Expression,
expression is evaluated.
value1, expression1
If the result is not matched with any of the given values, and
[, value2, expression2] … else is given, the corresponding expression is evaluated.
[, else, expression] All expressions must be of the same data type.
)
TRUE() Returns the logical value TRUE.

Last updated 14th March 2020 Version 3.53


DAX Math and Trig Functions
DAX Math and Trig Functions are similar to Excel mathematical and trigonometric functions.
Function Notes
ABS(number) Removes the negative sign if it exists.
ACOS(number) Returns the arccosine, or inverse cosine, of a number. The
arccosine is the angle whose cosine is number. The returned
angle is given in radians in the range 0 (zero) to pi.
ACOSH(number) Returns the inverse hyperbolic cosine of a number. The
number must be greater than or equal to 1. The inverse
hyperbolic cosine is the value whose hyperbolic cosine is
number, so ACOSH(COSH(number)) equals number.
ASIN(number) Returns the arcsine, or inverse sine, of a number. The arcsine
is the angle whose sine is number. The returned angle is given
in radians in the range -pi/2 to pi/2.
ASINH(number) Returns the inverse hyperbolic sine of a number. The inverse
hyperbolic sine is the value whose hyperbolic sine is number,
so ASINH(SINH(number)) equals number.
ATAN(number) Returns the arctangent, or inverse tangent, of a number. The
arctangent is the angle whose tangent is number. The returned
angle is given in radians in the range -pi/2 to pi/2.
ATANH(number) Returns the inverse hyperbolic tangent of a number. Number
must be between -1 and 1 (excluding -1 and 1). The inverse
hyperbolic tangent is the value whose hyperbolic tangent is
number, so ATANH(TANH(number)) equals number.
CEILING( Rounds a number up, to the nearest integer or to the nearest
multiple of significance.
number,
significance
)
COMBIN( Returns the number of combinations for a given number of
items.
number,
Numeric arguments are truncated to integers.
number_chosen
If either argument is nonnumeric, COMBIN returns the
)
#VALUE! error value.
If number<0, number_chosen<0, or number<number_chosen,
COMBIN returns the #NUM! error value.

Last updated 14th March 2020 Version 3.53


Function Notes
COMBINA( Returns the number of combinations (with repetitions) for a
given number of items.
number,
• number must be greater than or equal to 0, and greater
number_chosen
than or equal to number_chosen.
) • number_chosen must be greater than or equal to 0.
If the value of either argument is outside of it’s constraints,
COMBINA returns the #NUM! error value.
If either argument is a non-numeric value, COMBINA returns
the #VALUE! error value.
Non-integer values are truncated.
COS(number) Returns the cosine of the given angle.
COSH(number) Returns the hyperbolic cosine of a number.
CURRENCY(value) The value of the expression evaluated and returned as a
currency type value.
DEGREES(angle) Converts radians into degrees.
DIVIDE( Safe divide function that gracefully handles a divide by zero
error.
numerator,
Performs division and returns alternate result or BLANK() on
denominator
division by 0.
[, alternate-result]
)
EVEN(number) Returns number rounded up to the nearest even integer.
EXP(number) Returns e raised to the power of a given number. The constant
e equals 2.71828182845904, the base of the natural logarithm.
FACT(number) Returns the factorial of a number, equal to
1*2*3*...number..
number should be a non-negative integer.
FLOOR( Rounds a number down, toward zero, to the nearest multiple
of significance.
number,
significance
)
GCD( Returns the greatest common divisor of two or more integers.
The greatest common divisor is the largest integer that divides
number1
both number1 and number2 without a remainder.
If only one number is given, the function returns the number
[, number2] … itself.
)
INT(number) Rounds a number down to the nearest integer.

Last updated 14th March 2020 Version 3.53


Function Notes
ISO.CEILING( Rounds number up, to the nearest multiple of significance.
number Rounds number up, to the nearest integer if significance is
omitted.
[, significance]
)
LCM( Returns the least common multiple of integers. The least
common multiple is the smallest positive integer that is a
number1
multiple of all integer arguments number1, number2, and so
[, number2] … on.
)
LN(number) Returns the natural logarithm of a number.
Natural logarithms are based on the constant e
(2.71828182845904).

LOG( Returns the logarithm of a number to the base you specify.


number, If base is omitted, it is taken as 10.
[base] You might receive an error if the value is too large to be
displayed.
)
LOG10(number) Returns the base-10 logarithm of a number.
MOD( Returns the remainder after a number is divided by a divisor.
The result always has the same sign as the divisor.
number,
If the divisor is 0 (zero), MOD returns an error. You cannot
divisor
divide by 0.
)
MROUND( Returns a number rounded to the desired multiple.
number,
multiple
)
ODD(number) Returns number rounded up to the nearest odd integer.
PERMUT( Returns the number of permutations for a given number of
objects that can be selected from number objects.
number,
A permutation is any set or subset of objects or events where
number_chosen
internal order is significant.
)
PI() Returns the value of Pi, 3.14159265358979, accurate to 15
digits.
POWER( Returns the result of a number raised to a power.
number,
power
)
Last updated 14th March 2020 Version 3.53
Function Notes
QUOTIENT( Performs division and returns only the integer portion of the
division result. Use this function when you want to discard the
numerator,
remainder of division.
denominator
)
RADIANS(angle) Converts degrees to radians.
RAND() Returns a random number greater than or equal to 0 and less
than 1, evenly distributed. The number that is returned
changes each time the cell containing this function is
recalculated.
RANDBETWEEN( Returns a random number in the range between two numbers
you specify.
bottom,
top
)
ROUND( Rounds a number to the specified number of digits.
number,
num_digits
)
ROUNDDOWN( Rounds a number down, toward zero.
number,
num_digits
)
ROUNDUP( Rounds a number up, away from 0 (zero).
number,
num_digits
)
SIGN(number) Determines the sign of a number, the result of a calculation, or
a value in a column. The function returns 1 if the number is
positive, 0 (zero) if the number is zero, or -1 if the number is
negative.
SIN(number) Returns the sine of the given angle.
SINH(number) Returns the hyperbolic sine of a number.
SQRT(number) Returns the square root of a number.
If the number is negative, the SQRT function returns an error.
SQRTPI(number) Returns the square root of (number * pi).
TAN(number) Returns the tangent of the given angle.
TANH(number) Returns the hyperbolic tangent of a number.

Last updated 14th March 2020 Version 3.53


Function Notes
TRUNC( Truncates a number to an integer by removing the decimal, or
fractional, part of the number.
number,
num_digits specifies the precision of the truncation; if
num_digits
omitted, 0 (zero).
)

Last updated 14th March 2020 Version 3.53


DAX Other Functions
These functions perform unique actions that cannot be defined by any of the categories.
Function Notes
CONVERT( Converts an expression of one data type to another.
Expression, Datatype can be any of the following.
Datatype • INTEGER (Whole Number)
) • DOUBLE (Decimal Number)
• STRING (Text)
• BOOLEAN (True/False)
• CURRENCY (Fixed Decimal Number)
• DATETIME (Date, Time, etc.)
ERROR(text) Raises an error with an error message.
VAR VarName = Expression Stores the result of an expression as a named variable, which
can then be passed as an argument to other measure
expressions. Once resultant values have been calculated for a
variable expression, those values do not change, even if the
variable is referenced in another expression.
VarName is the name of the variable (identifier).
• Supported character set: a-z, A-Z, 0-9.
• 0-9 are not valid as first character.
• __ (double underscore) is allowed as a prefix. No other
special characters are supported.
• Delimiters are not supported. For example, ‘VarName’ or
[VarName] will result in an error.
• Reserved keywords not allowed.
• Names of existing tables are not allowed.
• Empty spaces are not allowed.
Expression is a DAX expression which returns a scalar or table
value.
• Expression can contain another VAR declaration.
When referencing a variable:
• Measures cannot refer to variables defined outside the
measure expression, but can refer to functional scope
variables defined within the expression.
• Variables can refer to measures.
• Variables can refer to previously defined variables.
Columns in table variables cannot be referenced via
TableName[ColumnName] syntax.

Last updated 14th March 2020 Version 3.53


DAX Other Special Functions (X-Functions / Iterators)
These functions perform specific actions that complement the other DAX functions.
DAX Iterator Functions, called iterators for short, take a column or a table as the argument and aggregate
the values just as aggregation functions—but using a different approach. These functions aggregate the
values in a row context.
These are “X-functions" (i.e., any function that has an X on the end of the name). The iterators given below
also include statistical iterator functions.
DAX also has two financial functions that got added in Excel 2016.
Function Notes
AVERAGEX( Calculates the average (arithmetic mean) of a set of
expressions evaluated over a table.
table,
expression
)
CONCATENATEX( Concatenates the result of an expression evaluated for each
row in a table.
table,
expression
[, delimiter]
)
COUNTAX( The COUNTAX function counts nonblank results when
evaluating the result of an expression over a table.
table,
That is, it works just like the COUNTA function, but is used to
expression
iterate through the rows in a table and count rows where the
) specified expressions result in a nonblank result.
COUNTX( Counts the number of rows that contain a number or an
expression that evaluates to a number, when evaluating an
table,
expression over a table.
expression
)
GEOMEANX( Returns the geometric mean of an expression evaluated for
each row in a table.
table,
expression
)
MAXX( Returns the largest numeric value that results from evaluating
an expression for each row of a table.
table,
expression • The first argument can be a table name, or an expression
that evaluates to a table.
) • The second argument indicates the expression to be
evaluated for each row of the table.

Last updated 14th March 2020 Version 3.53


Function Notes
MEDIANX( Returns the median of an expression evaluated for each row
in a table.
table,
expression
)
MINX( Returns the smallest numeric value that results from
evaluating an expression for each row of a table.
table,
expression • The first argument can be a table name, or an expression
that evaluates to a table.
) • The second argument indicates the expression to be
evaluated for each row of the table.
PERCENTILEX.EXC( Returns the percentile number of an expression evaluated for
each row in a table.
table,
expression,
k
)
PERCENTILEX.INC( Returns the percentile number of an expression evaluated for
each row in a table.
table,
expression,
k
)
PRODUCTX( Returns the product of an expression evaluated for each row
in a table.
table,
expression
)
RANKX( Returns the ranking of a number in a list of numbers for each
row in the table argument.
table,
expression,
[value],
[order],
[ties]
)
STDEVX.P( Returns the standard deviation of the entire population.
table, expression is any DAX expression that returns a single scalar
value, where the expression is to be evaluated multiple times
expression
(for each row/context).
)

Last updated 14th March 2020 Version 3.53


Function Notes
SUMX( Returns the sum of an expression evaluated for each row in a
table.
table,
expression
)
VARX.P( Returns the variance of the entire population.
table,
expression
)
VARX.S( Returns the variance of a sample population.
table,
expression
)
XIRR(table, values, dates, [guess]) Returns the internal rate of return for a schedule of cash flows
that is not necessarily periodic.
XNPV(table, values, dates, rate) Returns the present value for a schedule of cash flows that is
not necessarily periodic.

Last updated 14th March 2020 Version 3.53


DAX Other Special Functions (Argument Functions)
In DAX, there are also some special functions that have a very specific purpose of usability in other DAX
functions only. i.e. they can be used only as arguments to certain DAX functions. These functions cannot
be used as standalone functions.
Function Notes
CURRENTGROUP() CURRENTGROUP can only be used in an expression
that defines a column within the GROUPBY function.
In-effect, CURRENTGROUP returns a set of rows from
the “table” argument of GROUPBY that belong to the
current row of the GROUPBY result.
The CURRENTGROUP function takes no arguments and
is only supported as the first argument to one of the
following aggregation functions: AverageX, CountAX,
CountX, GeoMeanX, MaxX, MinX, ProductX,
StDevX.S, StDevX.P, SumX, VarX.S, VarX.P.
IGNORE(expression) IGNORE function does not return a value.
IGNORE can be used as an expression argument to
SUMMARIZECOLUMNS function.
NONVISUAL(expression) Returns a table of values and used with
SUMMARIZECOLUMNS.
Marks a value filter in SUMMARIZECOLUMNS function
as not affecting measure values, but only applying to
group-by columns.
ROLLUPADDISSUBTOTAL( ROLLUPADDISSUBTOTAL function does not return a
value. It only specifies the set of columns to be
groupBy_columnName,
subtotalled.
isSubtotal_columnName,
ROLLUPADDISSUBTOTAL is used with
[groupBy_columnName, SUMMARIZECOLUMNS function.
isSubtotal_columnName], …
)
ROLLUPGROUP( ROLLUPGROUP can only be used as a
groupBy_columnName argument to the
groupBy_columnName,
ROLLUPADDISSUBTOTAL and / or the SUMMARIZE
groupBy_columnName functions.
) ROLLUPGROUP is used inside the
ROLLUPISSUBTOTAL function to reflect
ROLLUPGROUPs present in the supplied table
argument.

Last updated 14th March 2020 Version 3.53


Function Notes
ROLLUPISSUBTOTAL( ROLLUPISSUBTOTAL is used to define the supplied
table argument to the ADDMISSINGITEMS function.
groupingColumn,
The ADDMISSINGITEMS function requires that, if
isSubtotal_columnName,
ROLLUPISSUBTOTAL was used to define the supplied
[groupingColumn, table argument, ISSUBTOTAL columns corresponding
isSubtotal_columnName], … to each group by column, or ROLLUPGROUP, are
present in the supplied table argument. Also, the names
) of the ISSUBTOTAL columns must be supplied in the
ROLLUPISSUBTOTAL function inside
ADDMISSINGITEMS and they must match names of
Boolean columns in the supplied table argument. This
enables the ADDMISSINGITEMS function to identify
BLANK values stemming from the fact that a row is a
subtotal row from other BLANK values.

Last updated 14th March 2020 Version 3.53


DAX Parent and Child Functions
DAX Parent and Child functions help to manage data that is presented as a parent/child hierarchy in the
data model.
For more information read. Understanding Functions for Parent-Child Hierarchies in DAX.
Function Notes
PATH( Returns a delimited text string with the identifiers of all the
parents of the current identifier, starting with the oldest and
ID_columnName,
continuing until current.
parent_columnName
)
PATHCONTAINS( Returns TRUE if the specified item exists within the specified
path.
path,
item
)
PATHITEM( Returns the item at the specified position from a string
resulting from evaluation of a PATH function. Positions are
path,
counted from left to right.
position,
[type]
)
PATHITEMREVERSE( Returns the item at the specified position from a string
resulting from evaluation of a PATH function. Positions are
path,
counted backwards from right to left.
position,
[type]
)
PATHLENGTH(path) Returns the number of parents to the specified item in a given
PATH result, including self.

Last updated 14th March 2020 Version 3.53


DAX Query Functions
These DAX functions are helpful in writing queries in DAX. These functions return tables that can be used
in other DAX functions as input. The resulting tables are virtual and are not materialised.
DAX Studio is a great way to learn about table functions because you can “see” the tables materialised on
the screen. Read about DAX Studio as a tool to query your data model here.
http://exceleratorbi.com.au/getting-started-dax-studio/.
Function Notes
ADDCOLUMNS( Adds calculated columns to the given table or table
expression.
table,
name, expression
[, name, expression]

)
CROSSJOIN( Returns a table that contains the Cartesian product of all rows
from all tables in the arguments. The columns in the new table
table,
are all the columns in all the argument tables.
table
[, table]

)
DATATABLE( Returns a table declaring an inline set of values.
ColumnName1, Each of the columns is given a name and the data type of the
column is provided.
DataType1,
Then, the set of values is given –
ColumnName2,
{{Row 1 values},
DataType2, ...,
{Row 2 values},
{{Value1, Value2 …},

{Value1, Value2 …}, …
}
}
)
EXCEPT( Returns a table that contains the rows of one table minus all
the rows of another table.
table_expression1,
table_expression2
)
GENERATE( Returns a table with the Cartesian product between each row
in table1 and the table that results from evaluating table2 in the
table1,
context of the current row from table1.
table2
)

Last updated 14th March 2020 Version 3.53


Function Notes
GENERATEALL( Returns a table with the Cartesian product between each row
in table1 and the table that results from evaluating table2 in the
table1,
context of the current row from table1.
table2
)
GROUPBY( Returns a table with the selected columns for the
groupBy_columnName arguments and the grouped by
table,
columns designated by the name arguments.
[<groupBy_columnName1>],
[<name>, <expression>]
The GROUPBY function is similar to the SUMMARIZE
… function. However, GROUPBY does not do an implicit
) CALCULATE and the group isn’t placed into the filter context.

GENERATESERIES( Generates a table of values using the parameters provided


StartValue,
EndValue
[, IncrementValue]
)
INTERSECT(table, table) Returns the row intersection of two tables, retaining duplicates.
NATURALINNERJOIN( Performs an inner join of a table with another table.
leftJoinTable, The tables are joined on common columns (by name) in the
two tables.
rightJoinTable
If the two tables have no common column names, an error is
)
returned.
NATURALLEFTOUTERJOIN( Performs an inner join of a table with another table.
leftJoinTable, The tables are joined on common columns (by name) in the
two tables.
rightJoinTable
If the two tables have no common column names, an error is
)
returned.
ROW( Returns a table with a single row containing values that result
from the expressions given to each column.
name, expression
[, name, expression]

)

Last updated 14th March 2020 Version 3.53


Function Notes
SELECTCOLUMNS( Adds calculated columns to the given table or table
expression.
table,
SELECTCOLUMNS starts with an empty table and that is the
name, scalar_expression
only difference between ADDCOLUMNS and
[, name, scalar_expression] SELECTCOLUMNS.

)
SUMMARIZE( Returns a table of values for use in a query or inside a formula
that uses a table. If there are relationships between tables,
table,
always specify the table on the many side of the relationship
groupBy_columnName as the table parameter. This function is semantically similar to
[, groupBy_columnName] “group by” in SQL.

…,
name, expression,
[name, expression]

)
SUMMARIZECOLUMNS( Returns a summary table over a set of groups. A table which
includes combinations of values from the supplied columns,
groupBy_columnName
based on the grouping specified.
[, groupBy_columnName]
Only rows for which at least one of the supplied expressions
…, return a non-blank value are included in the table returned.
[filterTable] … If all expressions evaluate to BLANK/NULL for a row, that row
[, name, expression] … is not included in the table returned.

) A column cannot be specified more than once in the


groupBy_columnName.

Last updated 14th March 2020 Version 3.53


Function Notes
Table Constructor Returns a table of one or more columns.
{scalar_expression1, • When there is only one column, the name of the column is
scalar_expression2, … Value.
• When there are N columns where N > 1, the names of the
} columns from left to right are Value1, Value2, …, ValueN.
Note:
{(scalar_expression11, • The number of scalar expressions must be the same for all
scalar_expression12, …, rows.
• When the data types of the values for a column are
scalar_expression1N different in different rows, all values are converted to a
), common data type.
(scalar_expression21),
scalar_expression22, …,
scalar_expression2N
),

}

UNION( Creates a union (join) table from a pair of tables.


table_expression1, Returns a table that contains all the rows from each of the two
table expressions.
table_expression2
The two tables must have the same number of columns.
)
Columns are combined by position in their respective tables.
The column names in the return table will match the column
names in table_expression1.
Duplicate rows are retained.
The returned table has lineage where possible. When data
types differ, the resulting data type is determined based on the
rules for data type coercion.
The returned table will not contain columns from related tables.

Last updated 14th March 2020 Version 3.53


DAX Statistical Functions
Following are the DAX Statistical Functions:
Function Notes
BETA.DIST( Returns the beta distribution. The beta distribution is commonly
used to study variation in the percentage of something across
x,
samples, such as the fraction of the day people spend watching
alpha, television.
beta,
cumulative
[, A]
[, B]
)
BETA.INV( Returns the inverse of the beta cumulative probability density
function (BETA.DIST).
probability,
If
alpha,
probability = BETA.DIST(x, ...TRUE),
beta
then
[, A]
BETA.INV(probability, ...) = x.
[, B]
)
CHISQ.INV( Returns the inverse of the left-tailed probability of the chi-squared
distribution.
probability,
The chi-squared distribution is commonly used to study variation
deg_freedom
in the percentage of something across samples.
)
CHISQ.INV.RT( Returns the inverse of the right-tailed probability of the chi-
squared distribution.
probability,
If
deg_freedom
probability = CHISQ.DIST.RT(x,...),
)
then
CHISQ.INV.RT(probability,...) = x.
Use this function to compare observed results with expected
ones in order to decide whether your original hypothesis is valid.
CONFIDENCE.NORM( The confidence interval is a range of values.
alpha, Your sample mean, x, is at the center of this range and the range
is x ± CONFIDENCE.NORM.
standard_dev,
size
)

Last updated 14th March 2020 Version 3.53


Function Notes
CONFIDENCE.T( Returns the confidence interval for a population mean, using a
Student's t distribution.
alpha,
standard_dev,
size
)
EXPON.DIST( Returns the exponential distribution. Use EXPON.DIST to model
the time between events.
x,
lambda,
cumulative
)
GEOMEAN(column) Returns the geometric mean of the numbers in a column.
MEDIAN(column) Returns the median of numbers in a column.
NORM.DIST(X, Mean, Standard_dev, Returns the normal distribution for the specified mean and
Cumulative) standard deviation.
NORM.INV(Probability, Mean, Returns the inverse of the normal cumulative distribution for the
Standard_dev) specified mean and standard deviation.
NORM.S.DIST(Z, Cumulative) Returns the standard normal distribution (has a mean of zero and
a standard deviation of one).
NORM.S.INV(Probability) Returns the inverse of the standard normal cumulative
distribution. The distribution has a mean of zero and a standard
deviation of one.
PERCENTILE.EXC( Returns the k-th percentile of values in a range, where k is in the
range 0..1, exclusive.
column,
k
)
PERCENTILE.INC( Returns the k-th percentile of values in a range, where k is in the
range 0..1, inclusive.
column,
k
)
POISSON.DIST( Returns the Poisson distribution.
x, A common application of the Poisson distribution is predicting the
number of events over a specific time.
mean,
cumulative
)

Last updated 14th March 2020 Version 3.53


Function Notes
RANK.EQ( Returns the ranking of a number in a list of numbers.
value,
columnName,
[order]
)
SAMPLE( Returns a sample of N rows from the specified table.
n_value,
table,
orderBy_expression,
[order]
[, orderBy_expression, [order], …]
)
STDEV.P(ColumnName) Returns the standard deviation of the entire population.
STDEV.S(ColumnName) Returns the standard deviation of a sample population.
T.DIST(X,Deg_freedom,Cumulative) Returns the Student's left-tailed t-distribution.
T.DIST.2T(X,Deg_freedom) Returns the two-tailed Student's t-distribution.
T.DIST.RT(X,Deg_freedom) Returns the right-tailed Student's t-distribution.
T.INV(Probability,Deg_freedom) Returns the left-tailed inverse of the Student's t-distribution.
T.INV.2T(Probability,Deg_freedom) Returns the two-tailed inverse of the Student's t-distribution.
VAR.P(ColumnName) Returns the variance of the entire population.
VAR.S(ColumnName) Returns the variance of a sample population.

Last updated 14th March 2020 Version 3.53


DAX Text Functions
DAX Text Functions are based on the Excel string functions, but have been modified to work with tables
and columns.
Function Notes
BLANK() Returns a blank.
Blanks are not equivalent to nulls. DAX uses blanks for both
database nulls and for blank cells in Excel.
CODE(text) Returns a numeric code for the first character in a text string.
The returned code corresponds to the character set used by
your computer.
COMBINEVALUES( Returns the concatenated string where the values of the DAX
expressions are joined by the delimiter (which is a constant).
delimiter,
expression, expression
[,expression] …
)
CONCATENATE( Joins two text strings into one text string.
text1, If you need to add more than two arguments, use the AND (&)
operator.
text2
)
CONTAINSSTRING( Returns TRUE or FALSE indicating whether one string
contains another string.
within_text,
find_text • CONTAINSSTRING is not case-sensitive.
• You can use ? and * wildcard characters. Use ~ to escape
) wildcard characters.
CONTAINSSTRINGEXACT( Returns TRUE or FALSE indicating whether one string
contains another string.
within_text,
find_text • CONTAINSSTRING is case-sensitive.

)
FIND( Returns the starting position of one text string within another
text string. FIND is case-sensitive.
find_text,
within_text
[, start_num]
[, NotFoundValue]
)

Last updated 14th March 2020 Version 3.53


Function Notes
FIXED( Rounds a number to the specified number of decimals and
returns the result as text. You can specify that the result be
number,
returned with or without commas.
decimals
[, no_commas]
)
FORMAT( Converts a value to text according to the specified format.
value,
format_string
)
LEFT( Returns the specified number of characters from the start of a
text string.
text
[,num_chars]
)
LEN(text) Returns the number of characters in a text string.
LOWER(text) Converts all letters in a text string to lowercase.
MID( Returns a string of characters from the middle of a text string,
given a starting position and length.
text,
start_num,
num_chars
)
REPLACE( REPLACE replaces part of a text string, based on the number
of characters you specify, with a different text string.
old_text,
start_num,
num_chars,
new_text
)
REPT( Repeats text a given number of times. Use REPT to fill a cell
with a number of instances of a text string.
text,
num_times
)
RIGHT( RIGHT returns the last character or characters in a text string,
based on the number of characters you specify.
text,
[num_chars]
)

Last updated 14th March 2020 Version 3.53


Function Notes
SEARCH( Returns the number of the character at which a specific
character or text string is first found, reading left to right.
find_text,
SEARCH function is case insensitive and accent sensitive.
within_text
[, start_num],
[, NotFoundValue]
)
SUBSTITUTE( Replaces existing text with new text in a text string.
text,
old_text,
new_text,
instance_num
)
TRIM(text) Removes all spaces from text except for single spaces
between words.
UNICHAR(number) Returns the Unicode character referenced by the numeric
value.
UPPER(text) Converts a text string to all uppercase letters
VALUE(text) You need not use the VALUE function in a formula because
Power Pivot implicitly converts text to numbers.
The argument text can be a constant or in one of the formats -
number, date or time format. Otherwise, an error is returned.
You can use a column reference as argument to VALUE
function. E.g., if you have a column that contains mixed
number types, VALUE can be used to convert all values to a
single numeric data type. However, if you use the VALUE
function with a column that contains mixed numbers and text,
the entire column is flagged with an error, because not all
values in all rows can be converted to numbers.

Last updated 14th March 2020 Version 3.53


DAX Time Intelligence Functions
DAX Time Intelligence Functions enable you to manipulate data using time periods, including days, months,
quarters and years, and then build and compare calculations over those periods.
There are 3 classes of DAX Time Intelligence functions based on their return value.
• Those that return scalar values (e.g. TOTALYTD). They are stand-alone functions and so can be used
as a stand-alone measure/function.
• Those that return a table containing a single column and single row with a date value (e.g.
FIRSTNONBLANK). They can be used either as stand-alone functions to define a measure (as a scalar
value) or as an argument to any function that requires a table in its arguments. These types of functions
therefore behave as both a scalar value and a table, depending on the use case.
• Those that return a table of dates (e.g. DATESYTD) and are designed to be used inside a CALCULATE
function.
DAX Time Intelligence Functions that return Scalar Values
Function Notes
CLOSINGBALANCEMONTH( Returns a scalar value that represents the expression
evaluated at the last date of the month in the current context.
expression,
E.g. Use to create a measure that calculates the 'Month End
dates,
Inventory Value' of the product inventory.
[filter]
)
CLOSINGBALANCEQUARTER( Returns a scalar value that represents the expression
evaluated at the last date of the month in the current context.
expression,
E.g. Use to create a measure that calculates the 'Quarter End
dates,
Inventory Value' of the product inventory.
[filter]
)
CLOSINGBALANCEYEAR( Returns a scalar value that represents the expression at the
last date of the year in the current context.
expression,
E.g. Use to create a measure that calculates the 'Year End
dates,
Inventory Value' of the product inventory.
[filter],
[year_end_date]
)
OPENINGBALANCEMONTH( Returns a scalar value that represents the expression
evaluated at the first date of the month in the current context.
expression,
E.g. You can create a measure that calculates the 'Month
dates
Start Inventory Value' of the product inventory.
[, filter]
)

Last updated 14th March 2020 Version 3.53


Function Notes
OPENINGBALANCEQUARTER( Returns a scalar value that represents the expression
evaluated at the first date of the quarter in the current context.
expression,
E.g. You can create a measure that calculates the ‘Quarter
dates
Start Inventory Value' of the product inventory.
[, filter]
)
OPENINGBALANCEYEAR( Returns a scalar value that represents the expression
evaluated at the first date of the year in the current context.
expression,
E.g. You can create a measure that calculates the ‘Year Start
dates
Inventory Value' of the product inventory.
[, filter]
)
TOTALMTD( Returns a scalar value that represents the expression
evaluated for the dates in the current month-to-date, given the
expression,
dates in dates.
dates
[, filter]
)

TOTALQTD( Returns a scalar value that represents the expression


evaluated for the dates in the current quarter-to-date, given the
expression,
dates in dates.
dates
[, filter]
)

TOTALYTD( Returns a scalar value that represents the expression


evaluated for the dates in the current year-to-date, given the
expression,
dates in dates.
dates
[, filter]
[, year_end_date]
)

DAX Time Intelligence Functions that return both a Table and a Scalar
These functions return a table containing a single column and single row with a date value (can be used as
a scalar value or a table input to another function).

Last updated 14th March 2020 Version 3.53


ENDOFMONTH(dates) Returns a table containing a single column and single row with
the last date of the month in the current context for the
specified column of dates.
Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
ENDOFQUARTER(dates) Returns a table containing a single column and single row with
the last date of the quarter in the current context for the
specified column of dates.
Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
ENDOFYEAR( Returns a table containing a single column and single row with
the last date of the year in the current context for the specified
dates
column of dates.
[, year_end_date]
Therefore, this function can be used as an argument to any
) function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
FIRSTDATE(dates) Returns a table containing a single column and single row with
the first date in the current context for the specified column of
dates.
Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
When the current context is a single date, the date returned by
the FIRSTDATE and LASTDATE functions will be equal.
FIRSTNONBLANK( Returns a table containing a single column and single row with
the first value in the column filtered by the current context,
column,
where the expression is not blank.
expression
Therefore, this function can be used as an argument to any
) function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
E.g. You could get the first value for which there were sales of
a product.
FIRSTNONBLANKVALUE( Evaluates an expression filtered by the sorted values of a
column and returns the first value of the expression that is not
column,
blank.
expression
This function is different from FIRSTNONBLANK in that the
) column is added to the filter context for the evaluation of
expression.
LASTDATE(dates) Returns a table containing a single column and single row with
the last date in the current context for the specified column of
dates.

Last updated 14th March 2020 Version 3.53


Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
When the current context is a single date, the date returned by
the FIRSTDATE and LASTDATE functions will be equal.
LASTNONBLANK( Returns a table containing a single column and single row with
the last value in the column, filtered by the current context,
column,
where the expression is not blank.
expression
Therefore, this function can be used as an argument to any
) function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
E.g. You could get the last value for which there were sales of
a product.
LASTNONBLANKVALUE( Evaluates an expression filtered by the sorted values of a
column and returns the last value of the expression that is not
column,
blank.
expression
This function is different from LASTNONBLANK in that the
) column is added to the filter context for the evaluation of
expression.
STARTOFMONTH(dates) Returns a table containing a single column and single row with
the first date of the month in the current context for the
specified column of dates.
Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.
STARTOFQUARTER(dates) Returns a table containing a single column and single row with
the first date of the quarter in the current context for the
specified column of dates.
Therefore, this function can be used as an argument to any
function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.

STARTOFYEAR( Returns a table containing a single column and single row with
the first date of the year in the current context for the specified
Dates,
column of dates.
[year end date]
Therefore, this function can be used as an argument to any
) function that requires a table in its arguments. Also, the
returned value can be used whenever a date value is required.

DAX Time Intelligence Functions that return a Table of Dates


DATEADD( Returns a table that contains a column of dates, shifted either
forward or backward in time by the specified number of
dates,
intervals from the dates in the current context.
number_of_intervals,
Designed to be used inside a CALCULATE as a table filter.

Last updated 14th March 2020 Version 3.53


interval If the number specified for number_of_intervals is positive,
the dates in dates are moved forward in time; if the number is
)
negative, the dates in dates are shifted back in time.
The interval parameter is an enumeration, not a set of strings.
Therefore, values should not be enclosed in quotation marks.
Also, the values: year, quarter, month, day should be spelled
in full when using them.
The result table includes only dates that exist in the dates
column.
If the dates in the current context do not form a contiguous
interval, the function returns an error.
DATESBETWEEN( Returns a table that contains a column of dates that begins
with the start_date and continues until the end_date.
dates,
Designed to be used inside a CALCULATE as a table filter.
start_date,
The DATESBETWEEN function is provided for working with
end_date
custom date ranges.
)
If you are working with common date intervals such as months,
quarters, and years, the more appropriate function is
DATESINPERIOD.
DATESINPERIOD( Returns a table that contains a column of dates that begins
with the start_date and continues for the specified
dates,
number_of_intervals.
start_date,
Designed to be used inside a CALCULATE as a table filter.
number_of_intervals,
If the number specified for number_of_intervals is positive,
interval the dates are moved forward in time; if the number is negative,
) the dates are shifted back in time.
The interval parameter is an enumeration, not a set of strings.
Therefore values should not be enclosed in quotation marks.
Also, the values: year, quarter, month, day should be spelled
in full when using them.
The result table includes only dates that appear in the values
of the underlying table column.
This function can be used as an input to CALCULATE to
create a rolling total such as Moving Annual Total (MAT),
rolling 90 days, rolling 90 day average etc.
DATESMTD(dates) Returns a table that contains a column of the dates for the
month to date, in the current context.
Designed to be used inside a CALCULATE as a table filter.
DATESQTD(dates) Returns a table that contains a column of the dates for the
quarter to date, in the current context.
Designed to be used inside a CALCULATE as a table filter.
DATESYTD( Returns a table that contains a column of the dates for the year
to date, in the current context.
dates
Designed to be used inside a CALCULATE as a table filter.
Last updated 14th March 2020 Version 3.53
[, year_end_date] year_end_date (optional) is a literal string with a date that
defines the year-end date. The default is December 31.
)
NEXTDAY(dates) Returns a table that contains a column of all dates from the
next day, based on the first date specified in the dates column
in the current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure that calculates the 'next day
sales' of the product sales.
NEXTMONTH(dates) Returns a table that contains a column of all dates from the
next month, based on the first date in the dates column in the
current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure that calculates the 'next
month sales' of the product sales.
NEXTQUARTER(dates) Returns a table that contains a column of all dates in the next
quarter, based on the first date specified in the dates column,
in the current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure that calculates the 'next
quarter sales' of the product sales.
NEXTYEAR( Returns a table that contains a column of all dates in the next
year, based on the first date in the dates column, in the current
dates
context.
[, year_end_date]
Designed to be used inside a CALCULATE as a table filter.
)
E.g. You can create a measure that calculates the 'next year
sales' of the product sales.

Last updated 14th March 2020 Version 3.53


PARALLELPERIOD( Returns a table that contains a column of dates that represents
a period parallel to the dates in the specified dates column, in
dates,
the current context, with the dates shifted a number of
number_of_intervals, intervals either forward in time or back in time.
interval Designed to be used inside a CALCULATE as a table filter.
) If the number specified for number_of_intervals is positive,
the dates in dates are moved forward in time; if the number is
negative, the dates in dates are shifted back in time.
The interval parameter is an enumeration, not a set of strings.
Therefore, values should not be enclosed in quotation marks.
Also, the values: year, quarter, month should be spelled in
full when using them.
The result table includes only dates that appear in the values
of the underlying table column.
The PARALLELPERIOD function is similar to the DATEADD
function except that PARALLELPERIOD always returns full
periods at the given granularity level instead of the partial
periods that DATEADD returns.
For example, if you have a selection of dates that starts at June
10 and finishes at June 21 of the same year, and you want to
shift that selection forward by one month then the
PARALLELPERIOD function will return all dates from the next
month (July 1 to July 31), however, if DATEADD is used
instead, then the result will include only dates from July 10 to
July 21.
PREVIOUSDAY(dates) Returns a table that contains a column of all dates
representing the day that is previous to the first date in the
dates column, in the current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure ‘Previous Day Sales’.

PREVIOUSMONTH(dates) Returns a table that contains a column of all dates from the
previous month, based on the first date in the dates column,
in the current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure ‘Previous Month Sales’.

PREVIOUSQUARTER(dates) Returns a table that contains a column of all dates from the
previous quarter, based on the first date in the dates column,
in the current context.
Designed to be used inside a CALCULATE as a table filter.
E.g. You can create a measure ‘Previous Quarter Sales’.

Last updated 14th March 2020 Version 3.53


PREVIOUSYEAR( Returns a table that contains a column of all dates from the
previous year, given the last date in the dates column, in the
dates
current context.
[, year_end_date]
Designed to be used inside a CALCULATE as a table filter.
)
E.g. You can create a measure ‘Previous Year Sales’.

SAMEPERIODLASTYEAR(dates) Returns a table that contains a column of dates shifted one


year back in time from the dates in the specified dates column,
in the current context.
Designed to be used inside a CALCULATE as a table filter.
The dates returned are the same as the dates returned by this
equivalent formula:
DATEADD(dates, -1, year)

Last updated 14th March 2020 Version 3.53

You might also like