Get certified for free when you join Fabric Data Days 2026 and dive into Fabric, Power BI, SQL, AI, and other essential data skills.
Join nowData Days is here! Join us now for 60+ days of learning, challenges, and connection. Learn more
From below links I learned that assigning keys can greatly improve performance.
Let's say I have several queries with steps that maintain query folding to an SQL server. Then I want to merge these queries into one table. There are some SQL tables that already have a key assignment, but there are also tables that lack key assignments. So I thought, let's assign these keys, but then I noticed it breaks the query folding. What would be better practice, assiging keys and break query folding, or assign no keys and keep query folding? Or can I make use of both in a different way?
As tested, we know that some functions prevent the query folding taking place, like Table.AddKey, Table.Buffer.
As the author of your first link said,
There aren’t any general rules I can give you though, you just need to make sure you test thoroughly.
Besides from the test of this blog, sometimes executing queries inside the Power Query engine itself is better than query folding.
Thus, it's hard to say which is unconditionally better.
We could make a test to monitor the performance of Power Query when running these queries.
There are different monitor tools for different kinds of data sources.
https://blog.crossjoin.co.uk/2018/07/16/process-monitor-power-query/
Best Regards
Maggie
Community Support Team _ Maggie Li
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Don't miss out on Data Days, June 15 through August 7. Learn Fabric, Power BI, SQL, AI and more.
Check out the May 2026 Power BI update to learn about new features.
| User | Count |
|---|---|
| 4 | |
| 4 | |
| 2 | |
| 2 | |
| 1 |
| User | Count |
|---|---|
| 11 | |
| 11 | |
| 5 | |
| 4 | |
| 4 |