- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/27094/27094888c106f7b7c98b700555c8e8d7d135d4a0" alt="Partially syndicated - Outbound Partially syndicated - Outbound"
How do I append two sources in DAX code instead of the append button?
Hi All,
I have two JSON sources.
Normally I would have to create two seperate JSON sources and append the 2nd to the first.
Can someone write me out the code to do it all in one?
Thanks!
Here is the first code, the 2nd code looks exactly the same just comes from a different system
let
Source = Json.Document(Web.Contents(" URL IS HERE ")),
(IS IT POSSIBLE TO JOIN THEM HERE, LIKE URL 1+ URL 2)
#"Converted to Table" = Table.FromRecords({Source}),
#"Expanded data" = Table.ExpandListColumn(#"Converted to Table", "data"),
#"Expanded data1" = Table.ExpandRecordColumn(#"Expanded data", "data", {"account_name"}, {"data.account_name"}),
#"Changed Type" = Table.TransformColumnTypes(#"Expanded data1",{{"data.account_name", type text}}),
#"Renamed Columns" = Table.RenameColumns(#"Changed Type",{{"data.account_name", "account_name"}})
in
#"Renamed Columns"
(OR IF THE FIRST ISINT POSSIBLE, THIS IS USUALLY WHERE THE APPEND SYNTAX IS THAT REFERS TO A DIFFERENT QUERY TABLE, IS IT POSSIBLE TO JUST UNION THE 2ND QUERY HERE)
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
Since the two sources are from different systems, I recommend that you remain them in two single queries. Power Query needs to treat them as from two data sources and it needs to store the credentials for these two data sources separately.
I think your final purpose is to only keep the appended result in the model, right? To meet this goal, you can use Append Queries as New to have the appended result in a third query, then unselect "Enable load" option for the two source queries. In this way, only the third "Append1" query will be loaded into the model. The two source queries will be used when appending but won't be loaded after that.
Best Regards,
Community Support Team _ Jing
If this post helps, please Accept it as Solution to help other members find it.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
I just want one table with 2 sources unioned together in code.
I dont want to have to do 2 seperate tables and combined.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
Ok, you may try this:
let
Source1 = Json.Document(Web.Contents(" URL IS HERE 1")),
Source2 = Json.Document(Web.Contents(" URL IS HERE 2")),
#"Converted to Table" = Table.FromRecords({Source1}),
#"Converted to Table2" = Table.FromRecords({Source2}),
CombineTables = Table.Combine({#"Converted to Table", #"Converted to Table2"}),
#"Expanded data" = Table.ExpandListColumn(CombineTables, "data"),
#"Expanded data1" = Table.ExpandRecordColumn(#"Expanded data", "data", {"account_name"}, {"data.account_name"}),
#"Changed Type" = Table.TransformColumnTypes(#"Expanded data1",{{"data.account_name", type text}}),
#"Renamed Columns" = Table.RenameColumns(#"Changed Type",{{"data.account_name", "account_name"}})
in
#"Renamed Columns"
Best Regards,
Community Support Team _ Jing
If this post helps, please Accept it as Solution to help other members find it.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
so here is the thing, it works when the columns are the same, but not when the 2nd source has different columns than the first, it gives me only the first table in the combine table.
For example:
if source 1 has account, impressions, conversionamount
if source 2 has account, impressions,revenueamount
it only gives me source 1 values, but if the column names are the same that error doesnt happen
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
For the last column that has a different name, you want to combine them into the same column after appending or into two columns with their own names? If you want to combine them into the same column, you need to rename either of them because the Table.Combine() functions works based on the column names. If you want to have them in different columns, I think that is currently what Table.Combine() does. I haven't met the scenario that it would lose the second table that has different column names.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
I want to the same column and I want to use the name of the first source as the column header.
so possibly a code before the combine.tables line that changes the name of certain columns in the 2nd source if you can write out a code like that for me.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
Please try this
RenameColumns = Table.RenameColumns(#"Converted to Table2", {{"revenueamount", "conversionamount"}}),
CombineTables = Table.Combine({#"Converted to Table", RenameColumns}),
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
Hi, this didnt work, do you have to expand first or something?
It says column not found but I know column exsists in the source 2, it gives me the error in the rename columns part.
Can you rewrite this?
let
Source1 = Json.Document(Web.Contents("https:/--Source1urlhere--account_name&_renderer=powerbi")),
Source2 = Json.Document(Web.Contents("https:/---Source2urlhere--account_name&_renderer=powerbi")),
#"Converted to Table1" = Table.FromRecords({Source1}),
#"Converted to Table2" = Table.FromRecords({Source2}),
#"RenameColumns" = Table.RenameColumns(#"Converted to Table2", {{"account_name", "account_name"}}), GIVES ME AN ERROR HERE
#"CombineTables" = Table.Combine({#"Converted to Table1", #"RenameColumns"})
in
#"CombineTables"
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
The first name should be the old column name existing in the second table to be changed, and the latter name is the new name for it. If it says column not found, it means that it cannot find the first name from #"Converted to Table2".
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
I know but the column does exsist in converted to table 2 cause if I expand it, its there. And i just changed it from account name to account name for testing purposes. can you write out the whole code from the beginning to see if it works, cause i tried it again with another table where i changed device_name to account_name and even though the json table has device_name, this piece of code cannot find it.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
It looks like your source step returns a record, so you can combine Source1 and Source2 like this:
CombineRecords = Record.Combine ( { Source1, Source2 } ),
#"Converted to Table" = Table.FromRecords ( CombineRecords )
If this post helps to answer your questions, please consider marking it as a solution so others can find it more quickly when faced with a similar challenge.
Proud to be a Microsoft Fabric Super User
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
data:image/s3,"s3://crabby-images/d4669/d46691430fb425413e4a0eb8579f00113a8f331b" alt="Syndicated - Outbound Syndicated - Outbound"
Tried this, only gives me the second record
data:image/s3,"s3://crabby-images/a76ea/a76eae41cf78d1ed7d591747a2407dfbbddc1d90" alt="avatar user"
Helpful resources
Join us at the Microsoft Fabric Community Conference
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Power BI Monthly Update - February 2025
Check out the February 2025 Power BI update to learn about new features.
Join our Community Sticker Challenge 2025
If you love stickers, then you will definitely want to check out our Community Sticker Challenge!
data:image/s3,"s3://crabby-images/46f3a/46f3a8f38fb3ed9fadfdf5698b07aad45a5c2178" alt="spinner"
Subject | Author | Posted | |
---|---|---|---|
09-09-2024 03:29 PM | |||
02-27-2023 01:29 PM | |||
09-19-2024 12:47 AM | |||
02-01-2023 09:39 AM | |||
Anonymous
| 08-17-2021 04:46 AM |
User | Count |
---|---|
30 | |
23 | |
18 | |
15 | |
11 |