Earn the coveted Fabric Analytics Engineer certification. 100% off your exam for a limited time only!
Hello everyone,
I’ve been struggling the past few days with DAX-formulas to compare several years.
On the internet there are several formulas but none of them gives me the result I want.
What’s the problem/challenge?
I’ve got 2 tables:
I want to compare the number of customers and the amount of Sales during the years 2014-2018.
The result in the end:
My measures:
Total Turnover = SUM (‘Model Fct_InvoiceLine’[InvoiceLineTotalAmountExclVAT]
Number of Customers =
CALCULATE (
DISTINCTCOUNT ( ‘Model Fct_InvoiceLine’[Customernumber] );
FILTER ( ALL ( ‘Model Fct_InvoiceLine’[Customernumber] ); [Total Turnover] <> 0 )
)
The numbers from the measures mentioned above seems to be right.
At this point I need to go further but I’m lost.
I think that I have to make a virtual table with customernumber and sales for each year and after that I want to compare those tables with each other. I thought to use EXCEPT and SELECTEDCOLUMNS but I don’t know exactly how to use them.
Can you help me?
Thanks in advance,
Cor
Hi @Anonymous
The function you neccesary need is SAMEPERIODLASTYEAR, or even better DATEADD.
With this function you can calculate multiple measures just changing intervals numbers.
About how clasiffy your clients, based on sales. You have to create a manual table, and then you can use Switch function to clasify each row or customer or whatever....
EnterpriseDNA has tutorials in youtube, but I cannot find it right now.
I've found this one from Curbal, which may help you with Virtual Tables and Summarize Function.
https://www.youtube.com/watch?v=-Ola264bKXk
Good luck!
Hi @Ciria,
Thanks for your reply!
I've tried and tried and uptil now I haven't found a solution. I've made a dummy model and hopefully you can help me to count the customers for each year and the Sales.
The data:
The report I want to calculate for each year:
The relationship I use between the 2 tables:
Hopefully you can help me with my challenge.
Thanks in advance,
Cor
Hi @Anonymous
Yesterday I was precisely watching a video in youtube about how manage a situation like yours.
https://www.youtube.com/watch?v=SOkBdbu4sVc&list=LLECfzwATlNAWnYdkkGLenGw&index=3&t=50s
There are three parts, but your model looks definately simpler than her one.
Take a look it and let me know if it works.
DISTINTCOUNT looks definately the formula you need. A Both direction relathionships I think is not necessary, single side could be ok.
Good Luck!
Hi @Ciria,
Thanks for your reply, weekly I see the Curbal DAX-Friday-videos, Ruth does a good job. 🙂
In the meantime I’ve made the DAX-formulas for New and Steady customers:
Can you help me with the formula for Lost customers? Now I have the numbers for New and Steady customers, how can I connect these numbers with the amount of Sales?
Thanks in advance,
Cor
Hi @Anonymous
I'm afraid of without having the model I cannot help you more, additionally your DAX looks pretty advanced, so I am not sure if I will be able to help you any further....
About your question, maybe this video helps you to clasify your customers....
https://www.youtube.com/watch?v=Nboy_u8Iv74&index=2&list=LLECfzwATlNAWnYdkkGLenGw
Keep me posted if it works!
Hi @Ciria,
Thanks for your reply!
Sam McKay makes wonderful videos and the video you mentioned is also an excellent video by Sam but the video doesn't help me to answer my questions. I'm still looking for a solution to connect the number of lost-steady and new customers to the Sales-amount and compare these figures with the figure of the previous year.
Is there someone who can help me?
Thanks in advance,
With kind regards,
Cor
Hi @Anonymous
What about the use of LASTNONBLANK??
This function may return the last date with sales for every customer. I guess adding a IF function you could classify every customer.
I guess a customer with no sales on the present year, may be classifed as "lost customer"?
Regards,
User | Count |
---|---|
126 | |
108 | |
99 | |
65 | |
62 |
User | Count |
---|---|
137 | |
116 | |
102 | |
71 | |
61 |