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 September 15. Request your voucher.
Hi, I'm not sure if this can be resolved using dax but I need to filter my data in a simple matrix or table visual and it feels easy but I'm struggling with it. I need to filter all orders that contain a selected product but than show all products for those orders.
Simplefied example:
I want to be able to have a filter on the dimension product and the result should be the table at the end which is showing the som by product for all orders that contain the selected product. Can anyone help me with this please?
Solved! Go to Solution.
Hi @SnoekL
For your question, here is the method I provided:
I used the data you provided
“FACT Orderlines”
Create a measure. Query all orders that contain the selected product.
Select_Product-Amount =
var select_product =
IF(
ISFILTERED('ProductDim'[Name]),
VALUES('ProductDim'[ID]),
BLANK()
)
var select_product_amount =
SUMX(
FILTER(
'FACT Orderlines',
CALCULATE(
CONTAINS(
'FACT Orderlines',
'FACT Orderlines'[ProductID],
select_product
),
ALLEXCEPT(
'FACT Orderlines',
'FACT Orderlines'[OrderID]
)
)
),
'FACT Orderlines'[Amount]
)
RETURN select_product_amount
Create a measure. Group and sum the product.
Product_amount =
SUMX(
FILTER(
ALL('FACT Orderlines'),
'FACT Orderlines'[ProductID] = MAX('FACT Orderlines'[ProductID])
),
[Select_Product-Amount]
)
Here is the result.
Regards,
Nono Chen
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Thanks that works great 🙂
Hi @SnoekL
For your question, here is the method I provided:
I used the data you provided
“FACT Orderlines”
Create a measure. Query all orders that contain the selected product.
Select_Product-Amount =
var select_product =
IF(
ISFILTERED('ProductDim'[Name]),
VALUES('ProductDim'[ID]),
BLANK()
)
var select_product_amount =
SUMX(
FILTER(
'FACT Orderlines',
CALCULATE(
CONTAINS(
'FACT Orderlines',
'FACT Orderlines'[ProductID],
select_product
),
ALLEXCEPT(
'FACT Orderlines',
'FACT Orderlines'[OrderID]
)
)
),
'FACT Orderlines'[Amount]
)
RETURN select_product_amount
Create a measure. Group and sum the product.
Product_amount =
SUMX(
FILTER(
ALL('FACT Orderlines'),
'FACT Orderlines'[ProductID] = MAX('FACT Orderlines'[ProductID])
),
[Select_Product-Amount]
)
Here is the result.
Regards,
Nono Chen
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
User | Count |
---|---|
15 | |
12 | |
8 | |
6 | |
6 |
User | Count |
---|---|
24 | |
20 | |
12 | |
9 | |
7 |