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

Data Days is here! Join us now for 60+ days of learning, challenges, and connection. Learn more

Reply
Syndicate_Admin
Administrator
Administrator

Generate consecutive calculated column from scratch

Good morning community.

Today I ask for help with a calculated column for a table, where I have a customer (ID_CLIENTE) that can be repeated several times and different sales dates (FECHA_VENTA), I need to generate a consecutive (CONSECUTIVE in red) starting from scratch (0) for each row where the customer repeats (ID_CLIENTE) and in ascending order of sales date (FECHA_VENTA), attached table example result:

ID_CLIENTEFECHA_VENTACONSECUTIVE
101/02/20211
122/03/20212
101/01/20210
203/06/20210
224/06/20211
227/06/20212
303/04/20211
302/02/20210
305/04/20212
306/04/20213

Thank you very much in advance for your support.

WEC

1 ACCEPTED SOLUTION
Anonymous
Not applicable

Hi @Syndicate_Admin 

Try this code to build a calculated column. You can use Earilier function to catch current row.

CONSECUTIVE = 
RANKX(FILTER('Table','Table'[ID_CLIENTE] = EARLIER('Table'[ID_CLIENTE])),'Table'[FECHA_VENTA],,ASC,Dense)-1

Result is as below.

1.png

Best Regards,
Rico Zhou

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickl

View solution in original post

4 REPLIES 4
parry2k
Super User
Super User

@Syndicate_Admin add new measure using following:

 

Rank1 = 
RANKX ( 
    FILTER( 
        ALLSELECTED ( 'Rank' ), 
        'Rank'[ID_CLIENTE] = MAX ( 'Rank'[ID_CLIENTE] ) 
    ), 
    CALCULATE ( 
        MIN ( 'Rank'[FECHA_VENTA] ) 
    ), , 
    ASC 
)  - 1 

 

Follow us on LinkedIn

 

Check my latest blog post The Power of Using Calculation Groups with Inactive Relationships (Part 1) (perytus.com) I would  Kudos if my solution helped. 👉 If you can spend time posting the question, you can also make efforts to give Kudos to whoever helped to solve your problem. It is a token of appreciation!

 

Visit us at https://perytus.com, your one-stop-shop for Power BI-related projects/training/consultancy.



Subscribe to the @PowerBIHowTo YT channel for an upcoming video on List and Record functions in Power Query!!

Learn Power BI and Fabric - subscribe to our YT channel - Click here: @PowerBIHowTo

If my solution proved useful, I'd be delighted to receive Kudos. When you put effort into asking a question, it's equally thoughtful to acknowledge and give Kudos to the individual who helped you solve the problem. It's a small gesture that shows appreciation and encouragement! ❤


Did I answer your question? Mark my post as a solution. Proud to be a Super User! Appreciate your Kudos 🙂
Feel free to email me with any of your BI needs.

Thank you very much for your prompt response!

Could you help me but as a calculated column? Thank you very much in advance.

Anonymous
Not applicable

Hi @Syndicate_Admin 

Try this code to build a calculated column. You can use Earilier function to catch current row.

CONSECUTIVE = 
RANKX(FILTER('Table','Table'[ID_CLIENTE] = EARLIER('Table'[ID_CLIENTE])),'Table'[FECHA_VENTA],,ASC,Dense)-1

Result is as below.

1.png

Best Regards,
Rico Zhou

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickl

Thank you very much for example! It helped me to solve this challenge... greetings from Guatemala. 🤓

Helpful resources

Announcements
Fabric Data Days is here Carousel

Fabric Data Days 2026

Don't miss out on Data Days, June 15 through August 7. Learn Fabric, Power BI, SQL, AI and more.

May Power BI Update Carousel

Power BI Monthly Update - May 2026

Check out the May 2026 Power BI update to learn about new features.

Power BI DataViz World Championships carousel

Power BI DataViz World Championships - June 2026

A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.