While working on a project I came across a scenario where I had to create a calculated column and reference the row value from a previous row context. So which means, while on a particular row of the data, I want to reference the data from a previous row or a group of rows. I was able to do this using a very useful DAX function and since It was a very interesting use case, I explored more and found out many other uses of this DAX function which can be easily integrated in your daily Power BI workflow. Click to Download Data We will see 5 use cases of "EARLIER" dax function which includes calculating Sumif Percent of grand total Running total Countif Countif with multiple conditions So if you are interested, keep reading! https://youtu.be/s3-F-jfSv38 Before we begin please not that this dax that we are going to see today will only work in calculated column and not on measures. The EARLIER function is a unique tool for creating calculated columns that need to evaluate data row by row. Its main strength lies in letting you reference values from a row context outside of the current one, allowing for powerful, layered calculations. Unlike general measures, which summarize data across an entire table, EARLIER works specifically within the context of individual rows, making it a great fit for calculations that depend on specific conditions or comparisons with other rows. Top 5 Usages of EARLIER dax function 1. Creating a SUMIF-like Calculation In Excel, the SUMIF function lets you sum values in a range based on a specified condition. In DAX, we can achieve similar results by using EARLIER in a calculated column. Here, we’ll calculate the total sales amount for each product in the Sales Subset table. Product Total = CALCULATE( SUM('Sales Subset'[Sales]), FILTER('Sales Subset', 'Sales Subset'[Product] = EARLIER('Sales Subset'[Product])) ) 2. Percentage of Grand Total Suppose we want to calculate a "Sales Percentage" column that shows each row's sales amount as a percentage of the total sales for that product. We can use EARLIER to reference the outer row context of Product for this calculation. Sales Percentage = DIVIDE( 'Sales Subset'[Sales], CALCULATE(SUM('Sales Subset'[Sales]),FILTER('Sales Subset','Sales Subset'[Product] = EARLIER('Sales Subset'[Product])))) 3. Running Totals and Cumulative Calculations Let’s create a calculated column called "Running Total" that shows the cumulative sales for each product up to the current row. We can use EARLIER to reference previous rows of Product and only add up sales from rows that have come before or match the current row. Running Total = CALCULATE( SUM('Sales Subset'[Sales]), FILTER('Sales Subset', 'Sales Subset'[Product] = EARLIER('Sales Subset'[Product]) && 'Sales Subset'[SalesID] EARLIER('Sales Subset'[Sales]))) Conclusion The EARLIER function in DAX offers a unique way to create complex, row-specific calculations that would be challenging or impossible to achieve with standard measures or Excel formulas alone. By capturing the outer row context, EARLIER allows DAX formulas to reference individual rows dynamically, making it an indispensable tool for data analysts working with calculated columns. Through this blog, we explored five different use cases for EARLIER: SUMIF-like Calculations: Using EARLIER to conditionally sum values, allowing you to display totals for each category directly within a table. Percentage of Grand Total: Achieving percentage values to track the proportion of specific values across rows. Running Totals: Creating a cumulative sum for each row, particularly useful for time-based data analysis. Counting Occurrences: Achieving COUNTIF-style functionality to track the frequency of specific values across rows. Conditional Aggregations: Using EARLIER for customized aggregations based on multiple criteria, enhancing the flexibility of DAX formulas. Each of these examples demonstrates the diverse ways in which EARLIER can streamline your analysis within a single table. With just a few lines of DAX, you can replicate common Excel functions like SUMIF and COUNTIF & calculate dynamic totals—all directly within Power BI. When to Use EARLIER vs. Other DAX Functions While EARLIER is powerful, it’s essential to use it judiciously. Since EARLIER works best for calculations that require row-specific comparisons or conditions, it might not be the most efficient choice for more straightforward aggregations or calculations that could be handled with standard DAX functions like SUMX or COUNTROWS. Understanding when and where to apply EARLIER is key to optimizing your data model and keeping your calculations efficient. Take Your DAX Skills to the Next Level Mastering EARLIER opens up new possibilities for creating meaningful insights directly within calculated columns, making it an essential function for DAX users. With practice, you’ll discover even more ways to use it, adapting these techniques to fit your own data scenarios. As you continue developing your DAX skills, remember that functions like EARLIER aren’t just tools—they’re ways to make data more actionable and insights more accessible. By leveraging its unique capabilities, you’re well-equipped to tackle complex analytical challenges with confidence. This ending ties together the examples, reinforces best practices, and encourages readers to explore further, leaving them with a clear understanding of EARLIER's potential in their DAX toolkit.