This time we’re going bigger than ever. Fabric, Power BI, SQL, AI and more. We're covering it all. You won't want to miss it.
Learn moreLevel up your Power BI skills this month - build one visual each week and tell better stories with data! Get started
Hi All,
I have an problem with querying data that comes from multiple SQL tables and outputs to a format such as Excel, so that I can identify gaps in data for end users and provide them a tool where they can record any data that needs to be completed.
My example tables are as follows:
jobplan table
| jpnum | description | duration | status | jobplanid |
| JP1000 | JP Description 1 | 8 | Active | 2101 |
jobtask table
| jptask | description | jpnum | jobplanid |
| 10 | JP task 1 | JP1000 | 2101 |
| 20 | JP task 2 | JP1000 | 2101 |
| 10 | JP task 1 | JP1000 | 1999 |
| 20 | JP task 2 | JP1000 | 1999 |
joblabour table
| craft | quantity | laborhrs | jptask | jobplanid | jpnum |
| ELEC | 2 | 8 | 2101 | JP1000 | |
| EXT-ELEC | 1 | 4 | 20 | 2101 | JP1000 |
| MECH | 2 | 8 | 2101 | JP1000 | |
| TA | 4 | 12 | 10 | 2101 | JP1000 |
| EXT-MECH | 1 | 4 | 10 | 2101 | JP1000 |
jobmaterial table
| itemnum | description | quantity | jobplanid | jpnum | jptask |
| 122 | GASKET | 1 | 2101 | JP1000 | 20 |
| 543 | Nut | 2 | 2101 | JP1000 | 20 |
| 67895 | Bolt | 1 | 2101 | JP1000 | 20 |
| 123 | GASKET | 1 | 1999 | JP1000 | 20 |
The desired output needs to be able to show a table that combines all this data, without duplicating all the rows for all the variables and group the common data to make it easier to read. Apologies if this isn't quite the righgt forum for this but I was hoping to do this in power query so that i can adjust the tool dynamically as data is updated. Happy to have a discussion in another forum, or offline from here if there is someone who has a solution, btu this isn't quite where it fits.
Thanks in advance, Craig
Desired output:
| jpnum | description | duration | status | jobplanid | jptask | description | jpnum | jobplanid | craft | quantity | laborhrs | jptask | jobplanid | jpnum | itemnum | description | quantity | jobplanid | jpnum | jptask |
| JP1000 | JP Description 1 | 8 | Active | 2101 | 10 | JP task 1 | JP1000 | 2101 | TA | 4 | 12 | 10 | 2101 | JP1000 | ||||||
| EXT MECH | 1 | 4 | 10 | 2101 | JP1000 | |||||||||||||||
| 20 | JP task 2 | JP1000 | 2101 | EXT-ELEC | 1 | 4 | 20 | 2101 | JP1000 | 122 | GASKET | 1 | 2101 | JP1000 | 20 | |||||
| 543 | Nut | 2 | 2101 | JP1000 | 20 | |||||||||||||||
| 67895 | Bolt | 1 | 2101 | JP1000 | 20 | |||||||||||||||
| ELEC | 2 | 8 | 2101 | JP1000 | ||||||||||||||||
| MECH | 2 | 8 | 2101 | JP1000 |
Solved! Go to Solution.
= List.Accumulate({"JobPlan","JobTask","JobLabour","JobMaterial"},"",(x,y)=>let a=Record.Field(#shared,y),b=List.Intersect({{"jpnum","jobplanid","jptask"},Table.ColumnNames(a),Table.ColumnNames(x)}),c=Table.ColumnNames(a),d=List.Transform(c,each if List.Contains(Table.ColumnNames(x),_) then y&"-"&_ else _),e=Table.NestedJoin(x,b,a,b,"n",JoinKind.FullOuter) in if x="" then a else Table.ExpandTableColumn(e,"n",c,d))
= List.Accumulate({"JobPlan","JobTask","JobLabour","JobMaterial"},"",(x,y)=>let a=Record.Field(#shared,y),b=List.Intersect({{"jpnum","jobplanid","jptask"},Table.ColumnNames(a),Table.ColumnNames(x)}),c=Table.ColumnNames(a),d=List.Transform(c,each if List.Contains(Table.ColumnNames(x),_) then y&"-"&_ else _),e=Table.NestedJoin(x,b,a,b,"n",JoinKind.FullOuter) in if x="" then a else Table.ExpandTableColumn(e,"n",c,d))
Hi Daniel, thanks for having a crack, this isn't quitre what I was after , but i'll keep working through it and see what I can get.
Check out the April 2026 Power BI update to learn about new features.
Sign up to receive a private message when registration opens and key events begin.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.