How to Use the Power BI DAX function GENERATE

What is the GENERATE Function in DAX?

The GENERATE function is a powerful DAX function that allows you to create new tables by iterating over the values of one or more columns in an existing table. This function is particularly useful when you want to create a table with combinations of values from different columns.

The syntax for the GENERATE function is as follows:

GENERATE ( ❰table❱, ❰values❱ )

Where `❰table❱` is the name of the table you want to iterate over, and `❰values❱` are the columns from that table you want to include in the new table.

Let's take a look at a practical example to better understand how this function works.

Example: Creating a Table with Combinations of Values

Suppose you have a table called "Sales" with the following columns: "Region", "Product", and "Sales Amount". You want to create a new table that shows the total sales by region and product. Here's how you can use the GENERATE function to achieve this:

Sales by Region and Product =


VALUES ( Sales[Region] ),

VALUES ( Sales[Product] )


In this example, we're using the VALUES function to extract the distinct values of the "Region" and "Product" columns from the "Sales" table. The GENERATE function then iterates over these values and creates a new table with all possible combinations of regions and products.

You can then use this new table in your data model to create visualizations, filters, and calculations based on the total sales by region and product.

Example: Creating a Calendar Table

Another common use case for the GENERATE function is to create a calendar table. A calendar table is a table that contains a row for each day between a start and end date. This table is useful for time-based analysis, such as calculating daily, weekly, or monthly averages, or comparing the performance of different periods.

Here's how you can use the GENERATE function to create a calendar table:

Calendar =


CALENDAR ( MIN ( Sales[Date] ), MAX ( Sales[Date] ) ),

VAR DateValue = [Date]



“Date”, DateValue,

“Year”, YEAR ( DateValue ),

“Quarter”, “Q” & FORMAT ( CEILING ( MONTH ( DateValue ) / 3 ), “0#” ),

“Month”, FORMAT ( DateValue, “MMM” ),

“Weekday”, FORMAT ( DateValue, “ddd” ),

“Day”, DAY ( DateValue )



In this example, we're using the CALENDAR function to create a list of dates between the minimum and maximum dates in the "Sales" table. We then use a variable called "DateValue" to store the current date value while iterating over the rows.

The RETURN statement creates a new row for each date value, with columns for the date, year, quarter, month, weekday, and day. You can customize this formula to include additional columns or calculations based on your specific needs.

Once you have created the calendar table, you can use it in your data model to create time-based aggregations and comparisons.

The GENERATE function is a powerful tool in the arsenal of any Power BI user. With this function, you can create new tables with combinations of values from existing tables, or create specialized tables for time-based analysis.

In this article, we've covered the basics of the GENERATE function and provided practical examples for you to follow. We hope this will help you unleash the full potential of Power BI and create insightful visualizations and analyses for your business.

Power BI DAX Training Courses by G Com Solutions (0800 998 9248)

Upcoming Courses

6-8 Jun 23 (London or Online)
8-10 Aug 23 (London or Online)
24-26 Oct 23 (London or Online)

Contact Us


    Your Name (required)


    Email (required)


    Training Course(s)

    Your Message

    Upload Example Document(s) (Zip multiple files)