We've captured the moments from FabCon & SQLCon that everyone is talking about, and we are bringing them to the community, live and on-demand. Starts on April 14th. Register now
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.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.
A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.
Share feedback directly with Fabric product managers, participate in targeted research studies and influence the Fabric roadmap.
| User | Count |
|---|---|
| 5 | |
| 3 | |
| 3 | |
| 2 | |
| 2 |
| User | Count |
|---|---|
| 10 | |
| 8 | |
| 7 | |
| 7 | |
| 5 |