March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
Hi,
I'm currently working on filtering out old BOM's which my company replaced with new ones.
Below, there is a table with BOM lines.
The same BOM always has the same parent_product_tmpl_id, but different BOM_id.
With that being said in the above scenario, I want to keep the most recent rows, which is row 3 and 4.
I tried solutions from the below videos, but unsuccessful.
I think I should mix these 2 solutions in my case, but I really don't know how.
https://www.youtube.com/watch?v=9dX9PK_KlSA
https://www.youtube.com/watch?v=S3X_HK7yl1w
Sample file:
https://drive.google.com/file/d/1ybE1_ju1nm8NZBMmlQ6_7PeBUc3izb4p/view?usp=sharing
Solved! Go to Solution.
Hi @pawelj795
Download example PBIX file and data
I'm not sure I've followed your logic totally as I end up with a LOT of rows for each parent_product_tmpl_id.
But according to what you've described I soudl be grouping on the parent_product_tmpl_id field and not the bom_id field.
In my file above, check the Merge1 query for this results table. I had to recreate your data from your tables in the Data Model as I couldn't open your query and access your SQL source. The data is with the PBIX file above.
Regards
Phil
Proud to be a Super User!
Hello,
You can solve this problem in both DAX and Power Query in which grouping by is not neccesary.
You want to define the latest record as the current record and define records with an older date as history.
The solution in DAX would look like:
COLUMN =
VAR LatestRecordParentID =
CALCULATE(
MAX( table[create_date] ) ,
ALLEXCEPT( table , [parent_product_tmpl_id] ) ,
)
RETURN
IF(
table[create_date] = LatestRecordParentID ,
"Current record" ,
"History record"
)
You can use this column to filter out previous records and only keep the current.
If you want to solve this problem in Power Query you can apply the same logic of the DAX formula using MAX and FOR EACH.
If you need any help, please let me know!
Hi @pawelj795
Download example PBIX file and data
I'm not sure I've followed your logic totally as I end up with a LOT of rows for each parent_product_tmpl_id.
But according to what you've described I soudl be grouping on the parent_product_tmpl_id field and not the bom_id field.
In my file above, check the Merge1 query for this results table. I had to recreate your data from your tables in the Data Model as I couldn't open your query and access your SQL source. The data is with the PBIX file above.
Regards
Phil
Proud to be a Super User!
@PhilipTreacy
Well, your result seems okay.
But, could you explain to me step by step, how you've done it?
Hi @pawelj795
1. The query called Table1 loads the data.
2. I duplicated this and the new query is called Table 1 (2).
3. I grouped the data by the parent_product_tmpl_id column and set the operation to pick the Max value (the latest date) from the create_date column
This results in a table that has 1 row per parent_product_tmpl_id showing the latest date associated with that id.
5. Merge the 2 queries (Merge as new to create a 3rd query) using these settings
What this does is pull the rows from Table1 that have the (latest) date shown in the Table1 (2) query for each parent_product_tmpl_id. All the other rows, the ones with earlier dates, are ignored.
6. Expand the Tables in the merged query to show the other columns you want.
Regards
Phil
Proud to be a Super User!
@pawelj795 Sorry, try again, I had to update the link.
https://d13ot9o61jdzpp.cloudfront.net/files/pbiforum/pawel.zip
Phil
Proud to be a Super User!
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
User | Count |
---|---|
114 | |
76 | |
57 | |
52 | |
44 |
User | Count |
---|---|
167 | |
117 | |
63 | |
57 | |
50 |