Our use of cookies

We use cookies to tailor your experience, gather analytics, and provide you with live assitance. By clicking "Accept" or continuing to browse our site you agree to the use of cookies. For more details please read our Cookie Policy.

Power BI Master/Detail Report from live SharePoint data

In the real-world, reporting often includes master/detail scenario in which a master list item is selected in order to get more details about the entity. In SharePoint, master data will be stored in a list that contains a lookup column of detail list/s, and getting data from multiple lists would require multiple data sources and then modelling their relationships in Power BI. In this blog, I will show you how easy it is to achieve a master-detail scenario on live data coming from SharePoint lists using AxioWorks SQList. We will start off by looking at the lists which we are going to use in this scenario and followed by how we can use SQList to synchronise data between SharePoint Lists and SQL Server database and to finish things off, we will look at how to generate a report which shows master data in one table and details in the other based on a selection.

Scenario

Create an orders report in Power BI showing the current orders in one table and order details in the other based on selection.

SharePoint Lists

For this demo, we will use five custom lists with some data in SharePoint.

Invoices list

  • This list contains all the orders data.
  • Columns
    • Title (Single Line of Text)
    • Customer  (Lookup)
    • Total Amount (Money)
    • Product IDs (lookup column linked to product list).

Customer List

  • It is a custom list that contains the data of the customer.
  • Columns
    • Title (Single Line of Text)
    • Address (Address of customer)

Product list

  • This list contains all the product data.
  • Columns
    • Title (Single Line of Text)
    • Unit Price (Money)
    • Current Stock (Number)
    • Category ID (lookup column linked to category list)

Category List

  • It is a custom list that contains data of all the product categories.
  • Columns
    • Title (Single Line of Text)
    • Category group ID (lookup column linked to Category groups list)

Category Group List

  • It is a custom list that contains data of all the product category groups.
  • Columns
    • Title (Single Line of Text)

Step-1: Create a Database in SQL Server

First off, we need a database that will be used for replicating the data coming from SharePoint lists.

  • Open SQL Server Management Studio and create a new database named “AxioWorksInvoices”.

Step-2: Replicate and Synchronise data to Database

Secondly, we need to replicate the data from SharePoint lists into the SQL Server database. We will use SQList to achieve that.

  • Open SQList Manager and click on “Create a new replication”.

  • Create a new SharePoint connection, enter the connection name and Table prefix
  • and select the SharePoint site which contains the lists and clicks next.

  • The next step is to select the replication lists, we will select the 3 lists which are going to be used for this exercise i.e. Invoices, Customer, Product, Category, and Category Group.

  • Next, enter the details for the destination SQL database connection which is the database we created earlier.

  • The last step is to give this replication a name, and keep the default options as checked and then click finish.
  • Once the replication is created, SQList replication service will start off for synchronising the SharePoint lists and SQL database.
  • Once the service is started, you will see that some tables have been created in the destination database including the tables for the lists which we selected.

Note: SQList will keep the database in-sync with the SharePoint lists which means any updates made in the lists will be replicated in this database as well.

  • The next step is to create a SQL view which will be used as a data source in the Power BI for fetching the data. We will use SQL View Designer to generate for defining the relationships between all the selected tables and then generating the view.

Step-3: Generate a report in Power BI

  • Let’s open up Power BI.
  • Create a Connection to the SQL database and then select the view we created earlier as a data source.

  • Right-click on the data source and click on the edit query which will open up the advanced query designer.
  • Use Group by to group the invoice data which will act as master data by selecting the invoice columns.

  • Once the data is grouped by invoice detail, expand the product information details by selecting the product-related columns.

  • Now our data source is ready to be used in the report.
  • Add two tables on the report page, First table will serve as a master table with invoice information.

  • The second table will serve as detail table with product information including all the products in the selected invoice.

  • To test it out select an invoice in the invoice table, the details related to the invoice will be displayed in the products table.

Conclusion

To summarise, today we saw how easy it is to generate a Power BI master and detail report using data from SharePoint lists if we use a SQL database and SQL View as a data source that has data replicated and synchronised using SQList so the report reflects live data from SharePoint.

Want to know more?

To download a 30 day trial of AxioWorks SQList or book a demo, please visit: /sqlist/

For information, contact us at info@axioworks.com

Latest articles

Build your Apps in MS Teams with MS Dataverse for Teams

27 Jun 2022

MS Teams has become one of the most widely used tools for team collaboration and communication in organizations using Microsoft echo-system for […]
[read article]

Dataverse: A one-stop-shop for your App data storage and management

24 May 2022

Data is at the centre of any business application development and is often the deciding factor for which tech. stack to be used for the development. […]
[read article]

AxioWorks Newsletter April 2022: Still working on the next release of SQList…

30 Apr 2022

Hello Reader, Welcome to another exciting issue of our monthly Newsletter! Each month, we try our best to bring to you content that is relevant and […]
[read article]

What’s coming in Power Platform Release wave one of 2022

21 Apr 2022

Due to the ever-rising popularity of the Power platform, Microsoft continues to focus on improving the usability and versatility of the Power […]
[read article]

AxioWorks Newsletter March 2022: Working on the next release of SQList

30 Mar 2022

Hello Reader, Welcome to another exciting issue of our monthly Newsletter! Each month, we try our best to bring to you content that is relevant and […]
[read article]

How to Efficiently Develop and Deploy Solutions in Power Platform

20 Mar 2022

With the Emergence of Low Code to No-Code development platforms, developers have been ever so busy developing solutions utilizing those platforms […]
[read article]

AxioWorks Newsletter February 2022: A good month

28 Feb 2022

Hello Reader, Welcome to another exciting issue of our monthly Newsletter! Each month, we try our best to bring to you content that is relevant and […]
[read article]

Five most awesome features in MS Lists

20 Feb 2022

Microsoft Lists previously known as SharePoint Lists have been widely used for maintaining and storing data in SharePoint and its usage has grown […]
[read article]

AxioWorks Newsletter January 2022: Hello 2022, good bye Covid (we hope)

31 Jan 2022

Hello Reader, Welcome to another exciting issue of our monthly Newsletter! Each month, we try our best to bring to you content that is relevant and […]
[read article]

What went down at MS Ignite 2021: Power Automate and Power Virtual Agent Edition

14 Jan 2022

When we talk about the biggest annual tech conferences of the year, Microsoft Ignite comes to mind where not only do we get a view of all their […]
[read article]

Get SharePoint and SQL news to your inbox

Stay up-to-date with industry news and trends, SQL and SharePoint innovations and all the latest from AxioWorks by subscribing to our monthly newsletter.

Subscribe to the AxioWorks newsletter

*