Combine Power BI and Azure Synapse Analytics Serverless to get timely actionable insights. In this blog post, you will create a Power BI report using the on-demand form of Azure Synapse Analytics. Get the best performance from the engine and pay only per usage!
In my previous post on Power BI and Azure Synapse Analytics, I highlighted how easy it is to build Power BI reports in Azure Synapse Analytics workspaces.
In the previous post, I used a provisioned database. Today, we’ll explore the serverless (on-demand) offering and connect to it using Power BI.
Table of Contents
The tutorial below has three sections:
- Create External Tables
- Create Power BI dataset
- Create Power BI report
Why should you query the information in a Data Lake using Azure Synapse Analytics external tables and not directly Power BI?
I believe that are two key reasons for doing this:
- Power BI only supports import mode when using information from your Data Lake. This means that you have limitations on the size of the dataset (either Power BI Pro or Power BI Premium). Import mode also makes it difficult to display recent or near real-time changes.
- Using the engine of Azure Synapse Analytics will bring great performance and big data capabilities to your reporting solutions, and it is fully integrated with your Azure data lake store.
Pre-requirements
For this example, we are going to be using 2 different AdventureWorks parquet files that you can download from this link.
- Sales_SalesOrderHeader_20200723.parquet
- Sales_SalesTerritory_20200723.parquet
Create external tables
First, create external tables in your Azure Synapse Analytics SQL serverless pool. You can create them without writing any lines of codes.
Since Azure Synapse Analytics on-demand does not store any data in the database, we’ll create a link definition between your Data Lake and the database. This takes advantage of the Synapse Analytics engine (Massively parallel processing system).
Create external table Sales Order Header
data:image/s3,"s3://crabby-images/433dd/433dd0c6d23147029b6a415c051d2dc8e8efafb5" alt="Create external table Sales Order Header Create external table Sales Order Header"
Azure Synapse Analytics can create the external table for us. We just need to provide the name of the database that we want to use (serverless is the default option), external table name, and the automatic option.
data:image/s3,"s3://crabby-images/4e31f/4e31fe2c30f9bf8624a9bfdafe684954d5a62444" alt="Create external table Create external table"
Then, you’ll be able to query the information.
data:image/s3,"s3://crabby-images/b70bf/b70bfad99e21238d253f91b2551a81ef3e81926f" alt="Query the information Query the information"
Create external table Territories
Now, repeat the same process for the territories file.
data:image/s3,"s3://crabby-images/1e572/1e5727d500a54f187bf563a7c88b0499b4f00049" alt="Create external table territories Create external table territories"
Territory file external table.
data:image/s3,"s3://crabby-images/fd2e8/fd2e85fb7607c219a534f2e703a9d017c2e4a265" alt="Create external table SQL on demand Create external table SQL on demand"
You can verify that the objects exist in your database by using the Data Hub.
data:image/s3,"s3://crabby-images/3c549/3c5494a027dc80d8e2ce52caf3daac125dfc44f8" alt="Data Hub Data Hub"
Create Power BI dataset
Next, to create a Power BI report, you need to have a linked service (check this blog post on how to create a Power BI report) and create the datasets (connected to your serverless external tables).
data:image/s3,"s3://crabby-images/993e1/993e1352ab148adf7fc79a5608033e11659bd8bc" alt="Create Power BI dataset Create Power BI dataset"
This screen starts the tutorial.
data:image/s3,"s3://crabby-images/5dd62/5dd62cdc430e39095a88282b74ebd6655a43c936" alt="Get started with Microsoft Power BI Get started with Microsoft Power BI"
First, select your database.
data:image/s3,"s3://crabby-images/d4729/d47299bd06209d96fa53e15ffc29a91c7e367afa" alt="Select your database"
Now, it’s time to download the Power BI template. This allows you to create a dataset.
data:image/s3,"s3://crabby-images/2c7d2/2c7d22f2fb87ed45b519b5d0eb2fe5b5ea8ac7a5" alt="Download .pbids file Download .pbids file"
data:image/s3,"s3://crabby-images/1f9e3/1f9e336fc71c6a90349b3b525ec5f5a1e9611fc9" alt=""
After that, open the report and select your datasets.
data:image/s3,"s3://crabby-images/1430c/1430cb5c844cbad8bccfa3da660b7b9876d11030" alt="Select datasets Select datasets"
In our scenario, we are going to use the direct query method that doesn’t require importing information into a Power BI report.
data:image/s3,"s3://crabby-images/5429d/5429d26518c1a94a06f08ac94e13e25aa389e95d" alt="Connection settings Connection settings"
Make sure that you create a relationship using the Territory Id column.
data:image/s3,"s3://crabby-images/66ca4/66ca4b74a79667efa1cecf50c0f76b2287d02f24" alt="Territory Id column Territory Id column"
We’ll build the report in Azure Synapse Analytics, so you can simply publish the dataset.
data:image/s3,"s3://crabby-images/7669b/7669b54b049cf9d49e93ba35359306b2799f3054" alt="Publish dataset Publish dataset"
Select the Azure Synapse Analytics workspace that you are using in your linked service.
data:image/s3,"s3://crabby-images/d6461/d646171003e04e5cbffd9291c5b2196545ec84ff" alt="Publish to Power BI Publish to Power BI"
The dataset will become available in your Azure Synapse Analytics workspace, but you still need to configure the dataset credentials.
data:image/s3,"s3://crabby-images/b9269/b9269da631980d917f9546f67954ba9421f68f43" alt="Configure dataset credentials Configure dataset credentials"
Configure the credentials for the Power BI dataset in the Power BI service.
data:image/s3,"s3://crabby-images/0917a/0917abf6c1885ab55c0cfb0ddedfa699cda8d030" alt="Power BI service"
Next, edit the credentials.
data:image/s3,"s3://crabby-images/77aee/77aeefacee06bba9ca6f6f25c67a1ebcbc5d6837" alt="Edit credentials on Azure Synapse Analytics Edit credentials on Azure Synapse Analytics"
And finally, select the authentication method to OAuth2.
data:image/s3,"s3://crabby-images/71a42/71a42f190ceab8381d99fa92822dd75616ba18ae" alt="Configure Direct Query Configure Direct Query"
Your dataset is ready!
data:image/s3,"s3://crabby-images/2783d/2783d9675a55ff19f6a6b0eb295da75a87b83d9e" alt="Dataset is ready Dataset is ready"
Create a Power BI Report
Now that you have external tables and a Power BI dataset; you can start building reports using the Direct Query method to your Data Lake parquet files.
data:image/s3,"s3://crabby-images/96840/9684076f995f0342fa350f5a979fe5bf6702b120" alt="Power BI report Power BI report"
Select your dataset.
data:image/s3,"s3://crabby-images/0ed19/0ed19efcd13229ac441fddc626fa7b9b1e048468" alt=""
Now, you are ready to start creating Power BI Reports!
data:image/s3,"s3://crabby-images/dad32/dad325c587d700d66cd7a97369a0bc1caee8eab6" alt="Start creating Power BI Reports Start creating Power BI Reports"
When you save the report, it will become available in your workspace. You can also share it.
data:image/s3,"s3://crabby-images/b583b/b583b76085d7ce37b7d5e5f9aeeb7c8d84167465" alt="Save a copy of report Save a copy of report"
data:image/s3,"s3://crabby-images/480eb/480eb806f7ea808fea8a8e11bc7db9c525af9c9a" alt="Save your report Save your report"
data:image/s3,"s3://crabby-images/7c108/7c108902de836966eb511576822ec7806aac28f4" alt="Az Synapse Analytics test Az Synapse Analytics test"
It will be available in Azure Synapse Analytics as well.
data:image/s3,"s3://crabby-images/42762/427624d6f19178d340aac28d3866f9eac337725c" alt="Available in Azure Synapse Analytics Available in Azure Synapse Analytics"
Summary
You’ve seen how easy it is to create external tables and Power BI reports in Azure Synapse Analytics using a serverless option (pay per usage).
Final Thoughts
I’m really satisfied with delivering actionable insights from end-to-end without writing a single line of code. This will certainly enable more users to start using the platform and get value out of it.
What’s next?
Looking ahead, I’ll be posting on some of the other features within Azure Synapse Analytics. Please leave a comment if there is anything that you would like to learn about.