Advance your Data & AI career with 50 days of live learning, dataviz contests, hands-on challenges, study groups & certifications and more!
Get registeredJoin us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.
 
					
				
		
I need a quick bit of help on Power BI. Consider a table showing Customer/Contracts and the dates those contracts were signed – a bit like this:
| Customer/Contract | Date | 
| Sky-ABC123 | 2018-06 | 
| Sky-ABC124 | 2018-06 | 
| Sky-ABC123 | 2019-06 | 
The problem is that we need to identify how many new were signed in each month. So in the above table Sky signed 2 new contracts in June 2018 but zero new ones in June 2019 as that is a renewal. Required output is below. Really we just needs a way to distinguish renewals from new – which can be done by finding the earliest date for each distinct customer/contract. I could manage this in SQL easily enough but have no idea how to do it in PowerBI. Can someone guide how to do this in PowerBI?
| Month | New Contracts | 
| 2018-06 | 2 | 
| 2019-06 | 0 | 
Solved! Go to Solution.
Hi @Anonymous
Sure,
CALCULATED modifies Filter Context
TREATAS applies context on Table Date and filters it to only __minDate Value
KEEPFILTERS ensures the value is not calculated for 01/06/2019 as no new contracts there.
You could simplify this syntax and remove TREATAS like below
VAR __minDate = 
CALCULATE( 
    MIN( 'Table'[Date] ), 
    ALL( 'Table' ), 
    VALUES( 'Table'[Customer/Contract] ) 
)
RETURN 
CALCULATE(
    COUNTROWS( 'Table' ),
    KEEPFILTERS( 'Table'[Date] = __minDate )
) + 0
Learn more about
TREATAS - https://www.sqlbi.com/blog/marco/2017/11/25/using-treatas-in-place-of-in-in-dax/
KEEPFILTERS - https://www.sqlbi.com/articles/using-keepfilters-in-dax/
Best Regards,
Mariusz
If this post helps, then please consider Accepting it as the solution.
Hi @Anonymous
Try this
Measure = 
VAR __minDate = 
CALCULATE( 
    MIN( 'Table'[Date] ), 
    ALL( 'Table' ), 
    VALUES( 'Table'[Customer/Contract] ) 
)
RETURN 
CALCULATE(
    COUNTROWS( 'Table' ),
    KEEPFILTERS( TREATAS( { __minDate }, 'Table'[Date] ) )
) + 0
@Mariusz Thanks for your quick reply, Could you please explain little bit in details how we are calcualting this measure, especially this part of the formula, I am quite new in DAX and trying to understand what does this part of DAX is:
CALCULATE(
    COUNTROWS( 'Table' ),
    KEEPFILTERS( TREATAS( { __minDate }, 'Table'[Date] ) )
) + 0
Hi @Anonymous
Sure,
CALCULATED modifies Filter Context
TREATAS applies context on Table Date and filters it to only __minDate Value
KEEPFILTERS ensures the value is not calculated for 01/06/2019 as no new contracts there.
You could simplify this syntax and remove TREATAS like below
VAR __minDate = 
CALCULATE( 
    MIN( 'Table'[Date] ), 
    ALL( 'Table' ), 
    VALUES( 'Table'[Customer/Contract] ) 
)
RETURN 
CALCULATE(
    COUNTROWS( 'Table' ),
    KEEPFILTERS( 'Table'[Date] = __minDate )
) + 0
Learn more about
TREATAS - https://www.sqlbi.com/blog/marco/2017/11/25/using-treatas-in-place-of-in-in-dax/
KEEPFILTERS - https://www.sqlbi.com/articles/using-keepfilters-in-dax/
Best Regards,
Mariusz
If this post helps, then please consider Accepting it as the solution.
@MariuszThanks a lot for your extended help. I appreciate your prompt reply and taking out time to answer it.
 
					
				
				
			
		
Join the Fabric FabCon Global Hackathon—running virtually through Nov 3. Open to all skill levels. $10,000 in prizes!
Check out the October 2025 Power BI update to learn about new features.
 
            | User | Count | 
|---|---|
| 10 | |
| 6 | |
| 4 | |
| 3 | |
| 3 | 
| User | Count | 
|---|---|
| 13 | |
| 11 | |
| 8 | |
| 8 | |
| 8 |