Refreshing Datasets Automatically with Power BI Dataflows
data:image/s3,"s3://crabby-images/8689e/8689edb22b11d06f6c790d048d63e723d0f81c61" alt="Workspace showing the link from web to workspace to dataset to report."
I have a report, Open Issues, that has a Power BI dataflow as a data source. If I just use scheduled refreshes, my options are limited. I need to be refreshing datasets automatically after the dataflow has finished so my reports are up to date as soon as possible to avoid a situation where I schedule the dataflow to refresh at 10am and the next slot available might be 10:30am, for example. This can be done using Power Automate.
Create a flow in Power Automate
Head to Power Automate at https://flow.microsoft.com/ and click on Create on the left hand side menu. The flow will be triggered by the dataflow refresh finishing. This means it is automated so click on Automated cloud flow.
data:image/s3,"s3://crabby-images/dcda2/dcda283a0d1b8179ffd096aacab41873e32448de" alt="screen grab of Power Automate showing location of Create button and Automated cloud flow button"
A dialog appears asking for details of the flow. You need to enter in a name for the flow. Then in the search box enter in power to find relevant triggers. Select When a dataflow refresh completes and click Create.
data:image/s3,"s3://crabby-images/2629f/2629f98fea5b3c19e28692c7bc1ef7077e2f3aaf" alt="Build a flow dialog box"
After you click Create the flow editor appears with the trigger already added. For Group Type select Workspace. Then you can select the workspace name for Group. Then you can select the Dataflow.
data:image/s3,"s3://crabby-images/dff7b/dff7b2a57f5b3745b784a9c8e1223fdaf6f3ad89" alt="Trigger step showing values set for Group Type, Group and Dataflow"
We then need to refresh the connected report dataset. So we click New step. In the Choose an operation dialog, we type dataset into the search box. This will find you the action Refresh a dataset. We click on the action to add it to the flow.
data:image/s3,"s3://crabby-images/b3db8/b3db8c228f6381187bc22ee27df8b98ede35e7e1" alt="Adding the step for Refreshing datasets automatically"
Then you need to select the Workspace and Dataset in the action. The flow is complete, so we can click Save.
Testing the Flow
The flow triggers when the dataflow finishes refreshing. If we refresh the dataflow that will test the flow. I clicked refresh on the dataflow at 3pm and it triggered the flow which then refreshed the dataset.
data:image/s3,"s3://crabby-images/6a634/6a6341601860d964a7fd32f4aaeb95e7ff144d72" alt="Screen grabs of the workspace showing the refresh date and times and a screen grab from the flow runs showing the matching date and time."
In the workspace we can see the date and time of the refreshes and if the flow has worked correctly the dataset should be refreshed just after the dataflow. If you look at the history of the flow runs there should be a matching flow run just after the dataflow finished refreshing.
When refreshing datasets automatically fails
It is worth pointing out that if the dataset refresh fails the flow will not reflect that and will show succeeded in the flow runs. So it is worth checking that the dataset can refresh successfully.
Conclusion
This idea can be extended to refresh multiple datasets over multiple workspaces that are connected to the dataflow. This simplifies the process of scheduling refreshes. It also could allow for notifications to interested report owners to be told of the refreshes etc.
More Power Automate Posts
- Creating Adaptive Cards
- Refreshing Datasets Automatically with Power BI Dataflows
- Power Automate Child Flow
- Get data from a Power BI dataset
- Power Automate Button in a Power BI Report
- Write Me a Flow
- Power Automate and DevOps series
- Power Automate and Power BI Rest API series
- Save a File to OneLake Lakehouse
- Trigger Microsoft Fabric Data Pipeline using Power Automate
More Power BI Posts
- Conditional Formatting Update
- Data Refresh Date
- Using Inactive Relationships in a Measure
- DAX CrossFilter Function
- COALESCE Function to Remove Blanks
- Personalize Visuals
- Gradient Legends
- Endorse a Dataset as Promoted or Certified
- Q&A Synonyms Update
- Import Text Using Examples
- Paginated Report Resources
- Refreshing Datasets Automatically with Power BI Dataflows
- Charticulator
- Dataverse Connector – July 2022 Update
- Dataverse Choice Columns
- Switch Dataverse Tenancy
- Connecting to Google Analytics
- Take Over a Dataset
- Export Data from Power BI Visuals
- Embed a Paginated Report
- Using SQL on Dataverse for Power BI
- Power Platform Solution and Power BI Series
- Creating a Custom Smart Narrative
- Power Automate Button in a Power BI Report