The ultimate Fabric, Power BI, SQL, and AI community-led learning event. Save €200 with code FABCOMM.
Get registeredEnhance your career with this limited time 50% discount on Fabric and Power BI exams. Ends August 31st. Request your voucher.
Hi all,
I have 2 tables below
I need a new column, including Table A plus any new job with its cost of Tabel B
that would be like this
and the job numbers and costs in both tables are beings live and updated monthly. how can I calculate in power bi?
Thanks
Solved! Go to Solution.
This will work:
= Table.Combine({#"Table A", Table.SelectRows(#"Table B", each not List.Contains(List.Buffer(#"Table A"[Job NO]), [Job NO]))})
--Nate
Hello @Anonymous
I would suggest you to use a Join, applying LeftAnti. Here an example
let
A =
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WMlTSAeJYnWglIyDLCMwyBrKMlWJjAQ==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Job NO" = _t, Cost = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Job NO", Int64.Type}, {"Cost", Int64.Type}})
in
#"Changed Type",
B =
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WMlTSAeJYnWglIyDLCMwyA7KMwSxzIMtEKTYWAA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Job NO" = _t, Cost = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Job NO", Int64.Type}, {"Cost", Int64.Type}})
in
#"Changed Type",
AddTableBtoAUsingTableNestedJoin = Table.Combine
(
{
A,
Table.RemoveColumns
(
Table.NestedJoin
(
B,
"Job NO",
A,
"Job NO",
"A",
JoinKind.LeftAnti
),
{"A"}
)
}
)
in
AddTableBtoAUsingTableNestedJoin
Copy paste this code to the advanced editor in a new blank query to see how the solution works.
If this post helps or solves your problem, please mark it as solution (to help other users find useful content and to acknowledge the work of users that helped you)
Kudoes are nice too
Have fun
Jimmy
Hello @Anonymous
I would suggest you to use a Join, applying LeftAnti. Here an example
let
A =
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WMlTSAeJYnWglIyDLCMwyBrKMlWJjAQ==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Job NO" = _t, Cost = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Job NO", Int64.Type}, {"Cost", Int64.Type}})
in
#"Changed Type",
B =
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WMlTSAeJYnWglIyDLCMwyA7KMwSxzIMtEKTYWAA==", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Job NO" = _t, Cost = _t]),
#"Changed Type" = Table.TransformColumnTypes(Source,{{"Job NO", Int64.Type}, {"Cost", Int64.Type}})
in
#"Changed Type",
AddTableBtoAUsingTableNestedJoin = Table.Combine
(
{
A,
Table.RemoveColumns
(
Table.NestedJoin
(
B,
"Job NO",
A,
"Job NO",
"A",
JoinKind.LeftAnti
),
{"A"}
)
}
)
in
AddTableBtoAUsingTableNestedJoin
Copy paste this code to the advanced editor in a new blank query to see how the solution works.
If this post helps or solves your problem, please mark it as solution (to help other users find useful content and to acknowledge the work of users that helped you)
Kudoes are nice too
Have fun
Jimmy
This will work:
= Table.Combine({#"Table A", Table.SelectRows(#"Table B", each not List.Contains(List.Buffer(#"Table A"[Job NO]), [Job NO]))})
--Nate