Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Don't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.

Reply
pbrainard
Helper III
Helper III

Measure not able to be used as Filter

I've got this measure which is working in the view. This is a calculated table.

 

DatesOkay = IF(MAX('CTab'[End Date]) > MAX('CTab'[Start Date]), "YES", "NO")
 
pbrainard_1-1651426899332.png

 

But when I add a Data Card to do a DISTINCTCOUNT on IDs, and add the DatesOkay measure to the data card's filter, it won't let me do anything with it. I want to be able to filter my data card by DatesOkay = "YES". Clicking on Contains does nothing, and I can't add YES...liked it's locked or something, and it's not.

pbrainard_2-1651427164774.png

I'm assuming I have to create the column in the calculated table DAX, but can't seem to get it to work. Here's the table language...

CTab =
ADDCOLUMNS (
ADDCOLUMNS (
SUMMARIZE ( GAD_PHQ, GAD_PHQ[Client_ID], GAD_PHQ[Assess_Type] ),
"Start Date", CALCULATE ( MIN ( GAD_PHQ[Assess_Date] ) ),
"End Date", CALCULATE ( MAX ( GAD_PHQ[Assess_Date] ) )
),
"Start Score",
VAR _current_asset_type = GAD_PHQ[Assess_Type]
VAR _current_start_date = [Start Date]
RETURN
CALCULATE (
AVERAGE ( GAD_PHQ[Assess_Score] ),
GAD_PHQ[Assess_Date] = _current_start_date,
GAD_PHQ[Assess_Type] = _current_asset_type
),
"End Score",
VAR _current_asset_type = GAD_PHQ[Assess_Type]
VAR _current_end_date = [End Date]
RETURN
CALCULATE (
AVERAGE ( GAD_PHQ[Assess_Score] ),
GAD_PHQ[Assess_Date] = _current_end_date,
GAD_PHQ[Assess_Type] = _current_asset_type
)
)

 

2 ACCEPTED SOLUTIONS
bcdobbs
Community Champion
Community Champion

Adding this into your card visual I think should work:

 

Distinct Ids With Okay Dates = 
CALCULATE (
    DISTINCTCOUNT ( CTab[Client_Id] ),
    FILTER ( 
        CTab,
        CTab[End Date] > CTab[Start Date]
    )
)

 



Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

View solution in original post

bcdobbs
Community Champion
Community Champion

Actually moving the logic into your calculated table will be more efficient:

CTab =
ADDCOLUMNS (
    ADDCOLUMNS (
        SUMMARIZE ( GAD_PHQ, GAD_PHQ[Client_ID], GAD_PHQ[Assess_Type] ),
        "Start Date", CALCULATE ( MIN ( GAD_PHQ[Assess_Date] ) ),
        "End Date", CALCULATE ( MAX ( GAD_PHQ[Assess_Date] ) )
    ),
    "Start Score",
        VAR _current_asset_type = GAD_PHQ[Assess_Type]
        VAR _current_start_date = [Start Date]
        RETURN
            CALCULATE (
                AVERAGE ( GAD_PHQ[Assess_Score] ),
                GAD_PHQ[Assess_Date] = _current_start_date,
                GAD_PHQ[Assess_Type] = _current_asset_type
            ),
    "End Score",
        VAR _current_asset_type = GAD_PHQ[Assess_Type]
        VAR _current_end_date = [End Date]
        RETURN
            CALCULATE (
                AVERAGE ( GAD_PHQ[Assess_Score] ),
                GAD_PHQ[Assess_Date] = _current_end_date,
                GAD_PHQ[Assess_Type] = _current_asset_type
            ),
	"Dates Okay",
		IF (
			[End Date] > [Start Date],
			"Yes",
			"No"
			)
)

 

The measure can then filter a plane distinct count or write a measure like:

Distinct Ids With Okay Dates = 
CALCULATE (
    DISTINCTCOUNT ( CTab[Client_Id] ),
    CTab[Dates Okay] = "Yes"
)


Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

View solution in original post

10 REPLIES 10
bcdobbs
Community Champion
Community Champion

Sorry, misunderstood the question. Will have a play with your dax and get back to you.



Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!
bcdobbs
Community Champion
Community Champion

Adding this into your card visual I think should work:

 

Distinct Ids With Okay Dates = 
CALCULATE (
    DISTINCTCOUNT ( CTab[Client_Id] ),
    FILTER ( 
        CTab,
        CTab[End Date] > CTab[Start Date]
    )
)

 



Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

Like magic. Thank you!!!!

bcdobbs
Community Champion
Community Champion

Actually moving the logic into your calculated table will be more efficient:

CTab =
ADDCOLUMNS (
    ADDCOLUMNS (
        SUMMARIZE ( GAD_PHQ, GAD_PHQ[Client_ID], GAD_PHQ[Assess_Type] ),
        "Start Date", CALCULATE ( MIN ( GAD_PHQ[Assess_Date] ) ),
        "End Date", CALCULATE ( MAX ( GAD_PHQ[Assess_Date] ) )
    ),
    "Start Score",
        VAR _current_asset_type = GAD_PHQ[Assess_Type]
        VAR _current_start_date = [Start Date]
        RETURN
            CALCULATE (
                AVERAGE ( GAD_PHQ[Assess_Score] ),
                GAD_PHQ[Assess_Date] = _current_start_date,
                GAD_PHQ[Assess_Type] = _current_asset_type
            ),
    "End Score",
        VAR _current_asset_type = GAD_PHQ[Assess_Type]
        VAR _current_end_date = [End Date]
        RETURN
            CALCULATE (
                AVERAGE ( GAD_PHQ[Assess_Score] ),
                GAD_PHQ[Assess_Date] = _current_end_date,
                GAD_PHQ[Assess_Type] = _current_asset_type
            ),
	"Dates Okay",
		IF (
			[End Date] > [Start Date],
			"Yes",
			"No"
			)
)

 

The measure can then filter a plane distinct count or write a measure like:

Distinct Ids With Okay Dates = 
CALCULATE (
    DISTINCTCOUNT ( CTab[Client_Id] ),
    CTab[Dates Okay] = "Yes"
)


Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

Disregard!

I need one more calculation to bring this home. 

I need a column that I can filter on that indicates that the End Score is less than the Start Score. I tried to replicate the Dates Okay syntax, but the table DAX isn't recognizing the [End Date] or [Start Date]. When I use "End Date" and "Start Date" they all come back "YES". 

I was able to make another calculation to make this work (not in the table, but...)

Improved = CALCULATE(
DISTINCTCOUNT ( CTab[Client_Id] ),
(CTab[End Score] < CTab[Start Score]))



 

 

If you wanted to reference those columns you'd need another nested addcolumns before you do it. In my opinion that starts to get messy so would be better to try and refactor the whole thing using a set of variables. I'm out at the moment but will give it when I'm back.



Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!
bcdobbs
Community Champion
Community Champion

Hard to test I've not done some silly but I think this is what you want:

CTab =
GENERATE (
    SUMMARIZE ( GAD_PHQ, GAD_PHQ[Client_ID], GAD_PHQ[Assess_Type] ),
    VAR _StartDate =
        CALCULATE ( MIN ( GAD_PHQ[Assess_Date] ) )
    VAR _EndDate =
        CALCULATE ( MAX ( GAD_PHQ[Assess_Date] ) )
    VAR _current_asset_type = GAD_PHQ[Assess_Type]
    VAR _current_start_date = [Start Date]
    VAR _StartScore =
        CALCULATE (
            AVERAGE ( GAD_PHQ[Assess_Score] ),
            GAD_PHQ[Assess_Date] = _current_start_date,
            GAD_PHQ[Assess_Type] = _current_asset_type
        )
    VAR _current_asset_type = GAD_PHQ[Assess_Type]
    VAR _current_end_date = [End Date]
    VAR _EndScore =
        CALCULATE (
            AVERAGE ( GAD_PHQ[Assess_Score] ),
            GAD_PHQ[Assess_Date] = _current_end_date,
            GAD_PHQ[Assess_Type] = _current_asset_type
        )
    VAR _DatesOkay =
        IF ( _EndDate > _StartDate, "Yes", "No" )
    VAR _Improved =
        IF ( _EndScore > _StartScore, "Yes", "No" )
    RETURN
        ROW (
            "Start Date", _StartDate,
            "End Date", _EndDate,
            "Start Score", _StartScore,
            "End Score", _EndScore,
            "Dates Okay", _DatesOkay,
            "Improved", _Improved
        )
)


Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

Even better. They both work, but I like the idea of integrating into the table. Thank you!!!!!

bcdobbs
Community Champion
Community Champion

Try returning 1 and 0 instead of "Yes", "No". For some reason you can only filter in integers.



Ben Dobbs

LinkedIn | Twitter | Blog

Did I answer your question? Mark my post as a solution! This will help others on the forum!
Appreciate your Kudos!!

I can filter on the table without issue, but I can't apply the DatesOkay filter to a data card to get a count of IDs where DatesOkay = YES.

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

Jan25PBI_Carousel

Power BI Monthly Update - January 2025

Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.

Jan NL Carousel

Fabric Community Update - January 2025

Find out what's new and trending in the Fabric community.