Starting December 3, join live sessions with database experts and the Microsoft product team to learn just how easy it is to get started
Learn moreGet certified in Microsoft Fabric—for free! For a limited time, get a free DP-600 exam voucher to use by the end of 2024. Register now
Hi All,
I have two tables as below. I do not want to create a relationship between them.
Table 1:
Country | Value |
India | 10 |
Japan | 20 |
S Africa | 30 |
Brazil | 40 |
Table 2:
Place | Country |
Asia | India, Japan |
Africa | S Africa |
America | Brazil |
Table 2 has country mapped to places. For Asia, India and Japan has been mapped with a comma seperator. Now I need to use a DAX measure to calculate sum of Value (Table 1) based on the places. The result should be as follows:
Place | Value |
Asia | 30 |
Africa | 30 |
America | 40 |
I tried to create a measure like below but couldnt find an answer. Please help in creating a DAX measure for this.
Solved! Go to Solution.
hi @Anonymous
As amitchandak has suggested, in occasions like this, it is always advisible to split the column to rows in Power Query.
If your data is not big and you insist to do with DAX, you would try to
1) create a measure like this:
ValueSum =
VAR _country = MAX(Table2[Country])
RETURN
CALCULATE(
SUM(Table1[Value]),
FILTER(
ALL(Table1),
CONTAINSSTRING(_country, Table1[Country])
)
)
2) plot the measure and the place column as a Table Visual.
I tried and it worked like this:
@Anonymous If this post helps, please consider accept as solution to help other members find it more quickly.
@Anonymous -You have written the DAX Little bit correct you just need to do correction in that is this:-
Mark it as a solution if it meets your requirement
Thank You!
Hi,
Please check the below picture and the attached pbix file.
Value measure: =
SUMX (
DISTINCT ( 'Table 2'[Place] ),
CALCULATE (
SUMX (
FILTER (
GENERATE (
'Table 1',
ADDCOLUMNS (
ADDCOLUMNS ( 'Table 2', "@path", SUBSTITUTE ( 'Table 2'[Country], ", ", "|" ) ),
"@pathcontains", PATHCONTAINS ( [@path], 'Table 1'[Country] )
)
),
[@pathcontains] = TRUE ()
&& 'Table 2'[Place] = MAX ( 'Table 2'[Place] )
),
'Table 1'[Value]
)
)
)
If this post helps, then please consider accepting it as the solution to help other members find it faster, and give a big thumbs up.
hi @Anonymous
As amitchandak has suggested, in occasions like this, it is always advisible to split the column to rows in Power Query.
If your data is not big and you insist to do with DAX, you would try to
1) create a measure like this:
ValueSum =
VAR _country = MAX(Table2[Country])
RETURN
CALCULATE(
SUM(Table1[Value]),
FILTER(
ALL(Table1),
CONTAINSSTRING(_country, Table1[Country])
)
)
2) plot the measure and the place column as a Table Visual.
I tried and it worked like this:
@Anonymous , In table 2, use split by delimiters into rows and join with the first table
https://www.tutorialgateway.org/how-to-split-columns-in-power-bi/
Power Query Split Column , Split Column By Delimiter: https://youtu.be/FyO9Vmhcfag
refer if needed
Power BI- Text Part slicer to filter/search text - https://youtu.be/MKKWeOqFG4c
Starting December 3, join live sessions with database experts and the Fabric product team to learn just how easy it is to get started.
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early Bird pricing ends December 9th.
User | Count |
---|---|
87 | |
87 | |
84 | |
66 | |
49 |
User | Count |
---|---|
131 | |
110 | |
96 | |
70 | |
67 |