CALCULATETABLE
syntax:
CALCULATETABLE(<expression>[, <filter1> [, <filter2> [, …]]])
Every filter argument can be either a filter removal (such as ALL, ALLEXCEPT, ALLNOBLANKROW), a filter restore (ALLSELECTED), or a table expression returning a list of values for one or more columns or for an entire expanded table.
Example 1
with SUMX function
In this measure, CALCULATETABLE returns a filtered table where Item="Pen". SUMX function calculates SUM of all ItemSold for each row.
Total number of pen sold = SUMX( CALCULATETABLE(StoreA,StoreA[Item]="Pen") ,StoreA[ItemsSold])
data:image/s3,"s3://crabby-images/07696/07696350efe220b1fc84ed7f4a4d57d740ec05cd" alt=""
Example 2
with FILTER(ALL()...)
When a filter argument has the form of a predicate with a single column reference, the expression is embedded into a FILTER expression that filters all the values of the referenced column.
Average Male Salary = AVERAGEX( CALCULATETABLE(DimCustomer, FILTER( ALL(DimCustomer), DimCustomer[Gender]="M")) ,DimCustomer[Salary])
this function returns the average male's salary for each row.
data:image/s3,"s3://crabby-images/8e32b/8e32bd1fd6afc5429d475af2fbc2544645f01c82" alt=""
Example 3
This function calculates the salary for each row where birthdate is not null.
data:image/s3,"s3://crabby-images/fec1c/fec1c103c9b74bca7cf1e862447fa2eca07beae0" alt=""
EARLIER
Returns the value in the column prior to the specified number of table scans (default is 1).
syntax
EARLIER(<column>, <number>)
Example 1
adding a column to an existing table
in this example, I calculate the number of transactions in one particular day.
data:image/s3,"s3://crabby-images/98bd7/98bd760d7455f5b70047c2fd932f587204aa7f6e" alt=""
Example 2
EARLIER in measure.
...you can use SELECTCOLUMNS function instead of ADDCOLUMNS.
data:image/s3,"s3://crabby-images/c05a3/c05a37eef5558650cf3f6778fd77e13d1d0fc718" alt=""
Example 3
Calculate cumulative total
Earlie RT = CALCULATE( SUM(tblOrders[Quantity]), FILTER(tblOrders,EARLIER(tblOrders[Date],1)>=tblOrders[Date]))
data:image/s3,"s3://crabby-images/5b954/5b9548de9437bbb0943ce1b670f8ffeba437e813" alt=""
KEEPFILTERS
Modifies how filters are applied while evaluating a CALCULATE or CALCULATETABLE function.
syntax:
KEEPFILTERS(<expression>)
Example 1
Gill sales = CALCULATE(SUM(StoreA[ItemsSold]), KEEPFILTERS(StoreA[Person]="Gill"))
data:image/s3,"s3://crabby-images/a49a1/a49a1bbe12400e7c4553cdec723eadbf46c9e189" alt=""
Another way how to write this measure is using a combination of FILETER(VALUES(<table>)
data:image/s3,"s3://crabby-images/4f9eb/4f9ebcf390645daf707dc6dd9bf7356a95977b8b" alt=""
Example 2
I want to calculate a measure for the Product_A where Quantity > 5
Result = CALCULATE ( SUM ( tblOrders[Quantity] ), KEEPFILTERS ( FILTER ( ALL ( tblOrders[Product], tblOrders[Quantity] ), tblOrders[Product] = "Product_A" ) ), tblOrders[Quantity] > 5 )
data:image/s3,"s3://crabby-images/cc9b5/cc9b5630ec92ffcc061ba9fb631dfaf2f6bc9f08" alt=""
SELECTEDVALUE
Returns the value when there’s only one value in the specified column, otherwise returns the alternate result.
syntax:
SELECTEDVALUE(<columnName>[, <alternateResult>])
alternatively you can use
IF(HASONEVALUE(<columnName>),VALUES(<columnName>),<alternateResult>)
works nice with categorical data !
data:image/s3,"s3://crabby-images/7d333/7d3338946ff271f24f3e3682134dd27fb012f3ac" alt=""
Comments