Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.
Register now!To celebrate FabCon Vienna, we are offering 50% off select exams. Ends October 3rd. Request your discount now.
Hello everyone, I am looking for a way, through the data pipeline, to retrieve the last refresh time for each scheduled dataset.
I’m able to retrieve the Bearer token and list the datasets in a workspace. Then, I use a Foreach activity containing the condition @equals(item()?['isRefreshable'], true) to filter and get only the semantic models that are scheduled for refresh.
From this, I store the following values in a variable:
This allows me to retrieve the latest refresh of each dataset in the workspace.
Now, I would like to extract:
The id and name from the first loop,
As well as the refreshType (when it is "Scheduled"),
The endTime,
And the status,
All in a single row so I can store this data in a data warehouse.
Solved! Go to Solution.
Hi @jkrumb ,
To get everything in a single row, you can do the following inside your second Foreach loop (the one calling /refreshes?$top=1):
{ "id": "@{item().id}", "name": "@{item().name}", "refreshType": "@{activity('YourWebActivityName').output.value[0].refreshType}", "endTime": "@{activity('YourWebActivityName').output.value[0].endTime}", "status": "@{activity('YourWebActivityName').output.value[0].status}" }
⚠️ Make sure to handle cases where value[0] might be null (e.g., no refresh history yet) to avoid runtime errors.
Let me know if you want help with the full pipeline JSON or error handling logic.
If my response resolved your query, kindly mark it as the Accepted Solution to assist others. Additionally, I would be grateful for a 'Kudos' if you found my response helpful.
Thank's you for your return,
I had to make a change, but now everything's working fine — I'm getting the information I wanted. Thank you very much for your help!
Modification:
{
"id": "@{json(item())?['id']}",
"name": "@{json(item())?['name']}",
"refreshType": "@{first(activity('Myactivity').output.value)?['refreshType']}",
"endTime": "@{first(activity('Myactivity').output.value)?['endTime']}",
"status": "@{first(activity('Myactivity').output.value)?['status']}"
}
Exemple Output :
{
"variableName": "final",
"value": "{\n \"id\": \"0xxx-xxxc-xxxx-xxxxx-xxxxxx\",\n \"name\": \"MON RAPPORT 1\",\n \"refreshType\": \"OnDemand\",\n \"endTime\": \"2024-09-17T09:52:58.823Z\",\n \"status\": \"Completed\"\n}\n\n\n"
}
{
"variableName": "final",
"value": "{\n \"id\": \"0xxx-xxxc-xxxx-xxxxx-xxxxxx\",\n \"name\": \"MON RAPPORT 2\",\n \"refreshType\": \"Scheduled\",\n \"endTime\": \"2025-05-26T07:10:24.75Z\",\n \"status\": \"Completed\"\n}\n\n\n"
}
Hi @jkrumb ,
To get everything in a single row, you can do the following inside your second Foreach loop (the one calling /refreshes?$top=1):
{ "id": "@{item().id}", "name": "@{item().name}", "refreshType": "@{activity('YourWebActivityName').output.value[0].refreshType}", "endTime": "@{activity('YourWebActivityName').output.value[0].endTime}", "status": "@{activity('YourWebActivityName').output.value[0].status}" }
⚠️ Make sure to handle cases where value[0] might be null (e.g., no refresh history yet) to avoid runtime errors.
Let me know if you want help with the full pipeline JSON or error handling logic.
If my response resolved your query, kindly mark it as the Accepted Solution to assist others. Additionally, I would be grateful for a 'Kudos' if you found my response helpful.
Thank's you for your return,
I had to make a change, but now everything's working fine — I'm getting the information I wanted. Thank you very much for your help!
Modification:
{
"id": "@{json(item())?['id']}",
"name": "@{json(item())?['name']}",
"refreshType": "@{first(activity('Myactivity').output.value)?['refreshType']}",
"endTime": "@{first(activity('Myactivity').output.value)?['endTime']}",
"status": "@{first(activity('Myactivity').output.value)?['status']}"
}
Exemple Output :
{
"variableName": "final",
"value": "{\n \"id\": \"0xxx-xxxc-xxxx-xxxxx-xxxxxx\",\n \"name\": \"MON RAPPORT 1\",\n \"refreshType\": \"OnDemand\",\n \"endTime\": \"2024-09-17T09:52:58.823Z\",\n \"status\": \"Completed\"\n}\n\n\n"
}
{
"variableName": "final",
"value": "{\n \"id\": \"0xxx-xxxc-xxxx-xxxxx-xxxxxx\",\n \"name\": \"MON RAPPORT 2\",\n \"refreshType\": \"Scheduled\",\n \"endTime\": \"2025-05-26T07:10:24.75Z\",\n \"status\": \"Completed\"\n}\n\n\n"
}
User | Count |
---|---|
25 | |
16 | |
13 | |
10 | |
10 |
User | Count |
---|---|
36 | |
32 | |
25 | |
22 | |
15 |