Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.
Hi Community,
So i have a table:
Database$SalesInvoiceLine
Containing columns:
Database$SalesInvoiceLine'[Posting Date]
Database$SalesInvoiceLine'[Sell-to Customer No_]
I'm am trying to filter out Customers who havent placed an order (so haven't been invoiced) > 2 months.
But: The returned value can NOT show Customers who both:
DID NOT place an order > 2 months
DID place an order >2 months
Have been searching the community for ages. And have been trying different formulas... for ages.
Hope someone can help me out!
Solved! Go to Solution.
Hi @NandoBI ,
Here is my sample data.
You need to create these new columns.
rank = RANKX ( FILTER ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] = EARLIER ( 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) ), 'Database$SalesInvoiceLine'[Posting Date], , ASC, DENSE )
previous date = CALCULATE ( FIRSTNONBLANK ( 'Database$SalesInvoiceLine'[Posting Date], 1 ), FILTER ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] = EARLIER ( 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) && 'Database$SalesInvoiceLine'[rank] = EARLIER ( 'Database$SalesInvoiceLine'[rank] ) - 1 ) )
result = VAR a = CALCULATE ( LASTDATE ( 'Database$SalesInvoiceLine'[Posting Date] ), ALLEXCEPT ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) ) RETURN IF ( DATEDIFF ( a, TODAY (), DAY ) > 60, TRUE, IF ( 'Database$SalesInvoiceLine'[previous date] <> BLANK () && DATEDIFF ( 'Database$SalesInvoiceLine'[previous date], 'Database$SalesInvoiceLine'[Posting Date], DAY ) > 60, TRUE, FALSE ) )
Then use filter to display your results.
Best Regards,
Eads
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Hi @NandoBI ,
Here is my sample data.
You need to create these new columns.
rank = RANKX ( FILTER ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] = EARLIER ( 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) ), 'Database$SalesInvoiceLine'[Posting Date], , ASC, DENSE )
previous date = CALCULATE ( FIRSTNONBLANK ( 'Database$SalesInvoiceLine'[Posting Date], 1 ), FILTER ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] = EARLIER ( 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) && 'Database$SalesInvoiceLine'[rank] = EARLIER ( 'Database$SalesInvoiceLine'[rank] ) - 1 ) )
result = VAR a = CALCULATE ( LASTDATE ( 'Database$SalesInvoiceLine'[Posting Date] ), ALLEXCEPT ( 'Database$SalesInvoiceLine', 'Database$SalesInvoiceLine'[Sell-to Customer No_] ) ) RETURN IF ( DATEDIFF ( a, TODAY (), DAY ) > 60, TRUE, IF ( 'Database$SalesInvoiceLine'[previous date] <> BLANK () && DATEDIFF ( 'Database$SalesInvoiceLine'[previous date], 'Database$SalesInvoiceLine'[Posting Date], DAY ) > 60, TRUE, FALSE ) )
Then use filter to display your results.
Best Regards,
Eads
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
User | Count |
---|---|
93 | |
85 | |
77 | |
68 | |
62 |
User | Count |
---|---|
113 | |
99 | |
96 | |
64 | |
58 |