Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.
Hi all,
we are building a complex ETL model using dataflows and I'd like to clarify how to use incremental refreshes on a P1 instance.
Our Requirements:
- A large dataset from a SQL server (~2 million records per day)
- Need history for the last 12 months minimum
- Need to join the data at each refresh to another dataflow ( ~12.5 million records)
- Daily updates
A partial diagram of what we are building is below, but the summary is:
- ingesting data into a staging dataflow with an incremental refresh
- loading it into a compute entity
- ingesting data into a transformation dataflow with an incremental refresh, rinse and repeat.
My question is should we use an incremental refresh in subsequent dataflows between linked objects and compute entities?
The reason why we want to propagate incremental refreshed between dataflows is to reduce the load on the P1 entity, particularly with joins: the dataset is currently running at ~360 million rows and joining with another 12 million records takes about 13 hours to run.
I am hoping to run the first data load to join the whole thing and save it and then only run the joins on one-two days of incrementally refreshed data, i.e. 2-4 million records, not the whole 360 million +.
However, this totally non-descriptive article from MS documentation tells me not to use incremental refresh between dataflows.
Am I going to screw the whole thing up by trying to improve it or am I reading this document wrong?
Solved! Go to Solution.
This has been a while since I posted the original question. We have implemented the incremental refresh between dataflows (for example, staging and processing dataflows) and it's been working excellent.
The confusion is between linked and compute entities, as mentioned above. The linked entities cannot be changed from downstream dataflows and so the question does not apply to them. But if you load your original data into a compute entity, then it is possible to implement IR between them.
In our case, it reduced the downstream processing of a large dataflow table (~500 million rows) from 4 hours to about 20 minutes.
This has been a while since I posted the original question. We have implemented the incremental refresh between dataflows (for example, staging and processing dataflows) and it's been working excellent.
The confusion is between linked and compute entities, as mentioned above. The linked entities cannot be changed from downstream dataflows and so the question does not apply to them. But if you load your original data into a compute entity, then it is possible to implement IR between them.
In our case, it reduced the downstream processing of a large dataflow table (~500 million rows) from 4 hours to about 20 minutes.
I'm still confused about this, as I asked what I think is a similar question here: https://community.fabric.microsoft.com/t5/Service/Incremental-Refresh-with-Linked-Referenced-Tables/...
Are you saying you implemented two incremental refreshes? One on the source staging table and another one on a linked referenced/computed entity?
I put an incremental refresh on the staging table when first bringing it in from an on-prem SQL server and it takes 30 seconds. But my linked referenced/computed entity to that staging table takes 3 minutes (I haven't done any transformations to it yet).
So I'm trying to figure out if I need to create a second incremental refresh on the downstream linked tables.
@MightyMicrobe, one more question if I may ask: when you enabled IR on your computed entity, did you have your Enhanced Configuration Engine for this dataflow set to Optimized or On?
I am asking this because it *seems* to work ONLY if ECE is not switched off. In my case, when ECE is switched off, I have error messages in the refresh log about invalid PBI credentials.
Thanks!
Hey @fred31330, we're dealing with pretty large tables (100-600 million rows) in our dataflows, and most of them are cascaded, so by default, we always set the Enhanced Engine to ON. I'm not sure if this is the best practice or, in some cases, enhanced compute should not be turned on, but this seems to work well.
We're on a P1 Premium if that helps.
Thanks for your feedback! Exactly what I needed.
Thanks for posting. According to arvindsingh802 answer it wasn't necessary to explicitely set-up incfremental refresh between dataflows, so glad to hear that this in fact can and should be done. Appreciated.
You are reading the Microsoft Article right, Incremental refresh between dataflows is not required if the source dataflow has incremental refresh implemented.
If this post helps, then please consider Accept it as the solution, Appreciate your Kudos!
Thanks for your reply. Does it mean that incremental refresh logic implemented at the source is propagated throughout all linked entities? Can you post a link to where I can read more?
Yes, linked entities are reference entity that does not create a replica itself that is why linked entities should not use incremental refresh if they reference a dataflow.
Premium features of dataflows - Power BI | Microsoft Docs
I think there's been a misunderstanding. We're not referring to incremental refresh on linked entities, but for computed entities. See the original post. Thanks!
I would also like to read the specifics on this.
Hi
I am wondering how you finally solved this challenge as I am in the same situation. Could you kindly share your feedback?
Thanks!
I was wondering the exact same thing myself - definitely interested to hear the answer.
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.
User | Count |
---|---|
19 | |
16 | |
14 | |
12 | |
11 |
User | Count |
---|---|
32 | |
25 | |
23 | |
19 | |
17 |