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

AxioWorks Newsletter September 2023: An exhilarating month.

30 Sep 2023

Hello Reader, September has been a bustling and exhilarating month for us at AxioWorks, filled with advancements, collaborations, and a whole lot of […]
[read article]

The Collaborative Pathway: Bridging Minds in the AI Ecosystem

19 Sep 2023

In recent days, I found myself immersed in an enlightening conversation with a friend, a fellow entrepreneur steering his ship in the vast sea of […]
[read article]

AxioWorks Newsletter August 2023: A month of milestones and innovation.

28 Aug 2023

Hello Reader, September seems to be a month of unexpected milestones and continued innovations at AxioWorks. As the summer wanes and the autumn […]
[read article]

Use Graph API in Power Automate to read large Excel files from SharePoint

28 Aug 2023

Power Automate, a part of Microsoft’s suite of tools, is increasingly becoming a preferred choice for automating workflows and business […]
[read article]

From Punch Cards to Python: Still Hitting the Keys in my 50s

16 Aug 2023

I spent the entire weekend writing code, not because of deadlines to meet or million-pound dreams, but for the kick that I still get from doing it. […]
[read article]

AxioWorks Newsletter July 2023: Unveiling AxioWorks’s latest successes and exciting innovations

27 Jul 2023

Hello Reader, We hope this monthly update finds you in good spirits. As always, we are eager to share the latest developments and exciting ventures […]
[read article]

AI and Data: The Symbiosis of Interaction and Accuracy

13 Jul 2023

Artificial Intelligence (AI) has rapidly emerged as a revolutionary technology that fundamentally alters the nature of human-machine interactions. […]
[read article]

AxioWorks Newsletter June 2023: SQList v8 Release, Webinars, and New Product Development

30 Jun 2023

Hello Reader, Greetings to all our valued customers and subscribers! We are thrilled to share some exciting updates and developments with you in this […]
[read article]

Safeguarding Secrets with Secure Strings and Environment Variables in the Power Platform

26 Jun 2023

In today’s interconnected digital landscape, safeguarding sensitive information and maintaining robust security measures is of paramount […]
[read article]

Case study: Streamlining Medical Trial Data Analysis in the Pharmaceutical industry

15 Jun 2023

In the ever-evolving landscape of the pharmaceutical industry, conducting medical trials and analysing the resulting data are critical for the […]
[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

*