03 GROUPBY
02 SUMMARIZE
01 SUMMARIZECOLUMNS
(Table manipulation functions )
SUMMARIZECOLUMNS
Returns a summary table.
Use it, if you want to add new table.
data:image/s3,"s3://crabby-images/0ceee/0ceee428102e7116918a124b15e6d819285a487d" alt=""
Remarks
This function does not guarantee any sort order for the results.
A column cannot be specified more than once in the groupBy_columnName parameter.
This function is not supported for use in DirectQuery mode when used in calculated columns or row-level security (RLS) rules.
Example 1
returns a distinct values from a column.
data:image/s3,"s3://crabby-images/3f108/3f108ba11cf40ee8e029cd0c31bb423a737bc29e" alt=""
Example 2
returns a filtered table.
data:image/s3,"s3://crabby-images/4017f/4017fc8e25839950c015431eff5a28dcd83d4206" alt=""
Example 3
returns a filtered table with a subtotal for gender column where country is UK
data:image/s3,"s3://crabby-images/10ec9/10ec96128df5828b55f1bb636d65a528f53059da" alt=""
Example 4
using multiple expressions with filtered table.
data:image/s3,"s3://crabby-images/00b86/00b86aee68ba587b852db058034f35d74c31667a" alt=""
Example 5
With IGNORE
Table is grouped by CustomerID column. If you use IGNORE, a categories with blank values will be return.
data:image/s3,"s3://crabby-images/0058b/0058b710eb5630188d5a1582907a0e1037b1131c" alt=""
Example 6
With ROLLUPADDISSUBTOTAL
ROLLUPADDISSUBTOTAL returns a grand total per CustomerID. CustomerID can be displayed just ones in the formula, otherwise we got error. Sum function returns a subtotal, together with IGNORE returning the blank values.
data:image/s3,"s3://crabby-images/8941b/8941ba0a266dbc688bbd844afb899e011d70c2f4" alt=""
SUMMARIZE
Returns a summary table.
Syntax:
SUMMARIZE (<table>, <groupBy_columnName>[, <groupBy_columnName>]…[, <name>, <expression>]…)
Parameters
table Any DAX expression that returns a table of data.
groupBy_ColumnName(Optional) The qualified name of an existing column used to create summary groups based on the values found in it. This parameter cannot be an expression.
name The name given to a total or summarize column, enclosed in double quotes.
expression Any DAX expression that returns a single scalar value, where the expression is to be evaluated multiple times (for each row/context).
Example 1
returns unique values.
data:image/s3,"s3://crabby-images/7b84a/7b84a6316becbb5963ad155cb6cf601201da102c" alt=""
Example 2
Emp : table name
Emp[Country]: column name I want to use to summarize (group) the data.
"Salary by Country" : New added column
SUM(Emp[Salary]): type of aggregation for the grouped data.
data:image/s3,"s3://crabby-images/94799/947991eaf3db2bb15f025ff3bfe676e72c9cf993" alt=""
Example 3
with FILTER
data:image/s3,"s3://crabby-images/71432/71432a90552fbdda0857c35df423032e7883f09d" alt=""
Example 4
with FILTER
Filters: Continent is Europe, Gender is Female
Summarizing by Country column
data:image/s3,"s3://crabby-images/ff254/ff254d17a4cb10a660fecf4abcf8358e6385a684" alt=""
Example 5
with ROLLUP
data:image/s3,"s3://crabby-images/dcced/dcced30395e8cc5e4ec0f5048b0b1bf0db64f3ff" alt=""
Example 6
with ISSUBTOTAL
"Total by Gender" : new column name
ISSUBTOTAL(Emp[Gender]) : function and column name for which I want to return true or false
data:image/s3,"s3://crabby-images/851f8/851f844e70a84eaaa8342f8f19620ada71096975" alt=""
GROUPBY
The GROUPBY function is similar to the SUMMARIZE function. However, GROUPBY does not do an implicit CALCULATE for any extension columns that it adds.
Example 1
returns a single column, list of the unique values.
data:image/s3,"s3://crabby-images/56bb6/56bb6ce076e1e4022067393110e408d9c0d54654" alt=""
Example 2
With CURRENTGROUP
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.
As you can see from this picture below, GROUPBY is not collaborating with all the aggregate functions. It supports only “X” aggregations function with CURRENTGROUP function.
data:image/s3,"s3://crabby-images/225e1/225e15ec7c45cdef04d779147a8de8f069f879b4" alt=""
working...
data:image/s3,"s3://crabby-images/41c5e/41c5ee32d8bad7ef8f61b5b142fce102357c311b" alt=""
Example 3
Nested GROUPBY
I want to return these max values by region
3.1
data:image/s3,"s3://crabby-images/44ac0/44ac0f3cb5a99c41cc302a4f9d4a80a60bdfd2c0" alt=""
3.2 Nested GROUPBY
GroupBy NESTED =
GROUPBY (
GROUPBY (
salesCat,
salesCat[Region],
salesCat[Category],
salesCat[Item],
"Units", SUMX ( CURRENTGROUP (), salesCat[Units] )
),
salesCat[Region],
"MAX UNITS SOLD", MAXX ( CURRENTGROUP (), [Units] )
)
data:image/s3,"s3://crabby-images/ea8b2/ea8b2b3cb0d9983bf1291a12773cef702e434cc1" alt=""
Example 4
GROUPBY with Filter
GROUPBY with Filter =
FILTER (
GROUPBY (
salesCat,
salesCat[Region],
salesCat[Category],
"Total sales", SUMX ( CURRENTGROUP (), salesCat[Units] * salesCat[UnitCost] )
),
salesCat[Region] = "West"
)
data:image/s3,"s3://crabby-images/798c9/798c97a15c6bb8fac63916a3fa5288408d83e512" alt=""
Example 5
GROUPBY with ADDCOLUMNS
this combination of code supports CALCULATE function and there's no need to use CURRENTGROUP function.
SYNTAX
ADDCOLUMNS(<table>, <name>, <expression>[, <name>, <expression>]…)
PARAMETERS
Term Definition
table Any DAX expression that returns a table of data.
name The name given to the column, enclosed in double quotes.
expression Any DAX expression that returns a scalar expression.
GROUPBY with ADDCOLUMNS =
ADDCOLUMNS (
GROUPBY ( Emp, Emp[Country], Emp[Gender] ),
"HEADCOUNT", CALCULATE ( COUNT ( Emp[Name] ) ),
"TOTAL SALARY", CALCULATE ( SUM ( Emp[Salary] ) )
)
Note: must use CALCULATE, otherwise SUM function is not working correctly.
data:image/s3,"s3://crabby-images/9b0d8/9b0d89b4b8d88cece6411d7e703d1f516de737af" alt=""
Example 6
GROUPBY with ADDCOLUMNS and FILTER
GROUPBY wth ADDCOLUMNS FILTER = FILTER( ADDCOLUMNS( GROUPBY(salesCat,salesCat[Region],salesCat[Category]), "COUNT UNITS SOLD",CALCULATE(SUM(salesCat[Units]))), salesCat[Region]="West")
data:image/s3,"s3://crabby-images/1221b/1221bab04ddfd52e6046d2f14b5fc532ed4079cb" alt=""
Comments