Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

View all the Fabric Data Days sessions on demand. View schedule

Reply
gab2020
Microsoft Employee
Microsoft Employee

Multiple Slicers from Multiple Columns

Hi,

 

I have a table built as following in Power BI.

gab2020_1-1595927666503.png

 

How to create 2 slicers to filter the table as follows:

IdentityNo. Slicer: A slicer with values from IdentityNo. 1, IdentityNo. 2 and IdentityNo. 3.

E.g. selecting 9232039 from the slicer will filter the table and output the entire 2nd row.

 

IdentityCountry Slicer: A slicer with values from IdentityCountry 1, IdentityCountry 2, IdentityCountry 3?

E.g. selecting MY from the slicer will filter the table and output the entire 2nd and 3rd rows.

 

How to create a card to do a distinct count of values from IdentityCountry 1, IdentityCountry 2, IdentityCountry 3?

E.g. Card of UK will show a total of 3 since UK appears 3 times in the 2nd, 3rd, 4th rows.

 

Thanks. 🙂

1 ACCEPTED SOLUTION
v-alq-msft
Community Support
Community Support

Hi, @gab2020 

 

Based on your description, I created data to reproduce your scenario. The pbix file is attached in the end. 

Table:

a1.png

 

Slicer No(a calculated table):

Slicer No = 
FILTER(
    DISTINCT(
        UNION(
            DISTINCT('Table'[IdentityNo.1]),
            DISTINCT('Table'[IdentityNo.2]),
            DISTINCT('Table'[IdentityNo.3])
        )
    ),
    [IdentityNo.1]<>BLANK()
)

 

Slicer Country:

Slicer Country = 
FILTER(
    DISTINCT(
        UNION(
            DISTINCT('Table'[IdentityCountry 1]),
            DISTINCT('Table'[IdentityCountry 2]),
            DISTINCT('Table'[IdentityCountry 3])
        )
    ),
    [IdentityCountry 1]<>BLANK()
)

 

You may create two measures as below.

Visual Control = 
IF(
    AND(
        SELECTEDVALUE('Table'[IdentityNo.1]) in DISTINCT('Slicer No'[IdentityNo])||
        SELECTEDVALUE('Table'[IdentityNo.2]) in DISTINCT('Slicer No'[IdentityNo])||
        SELECTEDVALUE('Table'[IdentityNo.3]) in DISTINCT('Slicer No'[IdentityNo]),
        SELECTEDVALUE('Table'[IdentityCountry 1]) in DISTINCT('Slicer Country'[IdentityCountry])||
        SELECTEDVALUE('Table'[IdentityCountry 2]) in DISTINCT('Slicer Country'[IdentityCountry])||
        SELECTEDVALUE('Table'[IdentityCountry 3]) in DISTINCT('Slicer Country'[IdentityCountry])
    ),
    1,0
)

Count UK = 
var tab = 
ADDCOLUMNS(
    'Table',
    "flag",
    IF(
        AND(
            'Table'[IdentityNo.1] in DISTINCT('Slicer No'[IdentityNo])||
            'Table'[IdentityNo.2] in DISTINCT('Slicer No'[IdentityNo])||
            'Table'[IdentityNo.3] in DISTINCT('Slicer No'[IdentityNo]),
            'Table'[IdentityCountry 1] in DISTINCT('Slicer Country'[IdentityCountry])||
            'Table'[IdentityCountry 2] in DISTINCT('Slicer Country'[IdentityCountry])||
            'Table'[IdentityCountry 3] in DISTINCT('Slicer Country'[IdentityCountry])
        ),
        1,0
    )
)
return
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 1]="UK"
    )
)+
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 2]="UK"
    )
)+
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 3]="UK"
    )
)

 

Finally you may put 'Visual Control' measure in the visual level filter and use 'IdentityNo', 'IdentityCountry' from 'Slicer No', 'Slicer Country' to filter the result.

a2.png

a3.png

a4.png

 

Best Regards

Allan

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

 

View solution in original post

8 REPLIES 8
v-alq-msft
Community Support
Community Support

Hi, @gab2020 

 

Based on your description, I created data to reproduce your scenario. The pbix file is attached in the end. 

Table:

a1.png

 

Slicer No(a calculated table):

Slicer No = 
FILTER(
    DISTINCT(
        UNION(
            DISTINCT('Table'[IdentityNo.1]),
            DISTINCT('Table'[IdentityNo.2]),
            DISTINCT('Table'[IdentityNo.3])
        )
    ),
    [IdentityNo.1]<>BLANK()
)

 

Slicer Country:

Slicer Country = 
FILTER(
    DISTINCT(
        UNION(
            DISTINCT('Table'[IdentityCountry 1]),
            DISTINCT('Table'[IdentityCountry 2]),
            DISTINCT('Table'[IdentityCountry 3])
        )
    ),
    [IdentityCountry 1]<>BLANK()
)

 

You may create two measures as below.

Visual Control = 
IF(
    AND(
        SELECTEDVALUE('Table'[IdentityNo.1]) in DISTINCT('Slicer No'[IdentityNo])||
        SELECTEDVALUE('Table'[IdentityNo.2]) in DISTINCT('Slicer No'[IdentityNo])||
        SELECTEDVALUE('Table'[IdentityNo.3]) in DISTINCT('Slicer No'[IdentityNo]),
        SELECTEDVALUE('Table'[IdentityCountry 1]) in DISTINCT('Slicer Country'[IdentityCountry])||
        SELECTEDVALUE('Table'[IdentityCountry 2]) in DISTINCT('Slicer Country'[IdentityCountry])||
        SELECTEDVALUE('Table'[IdentityCountry 3]) in DISTINCT('Slicer Country'[IdentityCountry])
    ),
    1,0
)

Count UK = 
var tab = 
ADDCOLUMNS(
    'Table',
    "flag",
    IF(
        AND(
            'Table'[IdentityNo.1] in DISTINCT('Slicer No'[IdentityNo])||
            'Table'[IdentityNo.2] in DISTINCT('Slicer No'[IdentityNo])||
            'Table'[IdentityNo.3] in DISTINCT('Slicer No'[IdentityNo]),
            'Table'[IdentityCountry 1] in DISTINCT('Slicer Country'[IdentityCountry])||
            'Table'[IdentityCountry 2] in DISTINCT('Slicer Country'[IdentityCountry])||
            'Table'[IdentityCountry 3] in DISTINCT('Slicer Country'[IdentityCountry])
        ),
        1,0
    )
)
return
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 1]="UK"
    )
)+
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 2]="UK"
    )
)+
COUNTROWS(
    FILTER(
        tab,
        [flag]=1&&
        [IdentityCountry 3]="UK"
    )
)

 

Finally you may put 'Visual Control' measure in the visual level filter and use 'IdentityNo', 'IdentityCountry' from 'Slicer No', 'Slicer Country' to filter the result.

a2.png

a3.png

a4.png

 

Best Regards

Allan

 

If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

 

Thanks @v-alq-msft .😀 Got it working as per sharing.

amitchandak
Super User
Super User

@gab2020 , create independent slicer , do not join with any of the countries. Or use cross join to remove join

 

Then try like

measure =
var _max = selectedvalue(Country[country])
return
calculate(count(Table[identity No]) , filter(Table , Table[IdentityCountry 1] = _max && Table[IdentityCountry 2] = _max && Table[IdentityCountry 3] = _max ))

 

measure =
var _max = allselected(Country[country]) // or use // values(Country[country])
return
calculate(count(Table[identity No]) , filter(Table , Table[IdentityCountry 1] in _max && Table[IdentityCountry 2] in _max && Table[IdentityCountry 3] in _max ))

 

You can do same for another slicer too

 

there is an example of cross filter here

https://community.powerbi.com/t5/Community-Blog/HR-Analytics-Active-Employee-Hire-and-Termination-tr...

 

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

Hi @amitchandak , not sure if i understand the independent slicer correctly.

Do you mean to add slicer individually per column?

I'm looking to have 2 separate slicers to output the table based on selection of similar columns in IdentityNo. and IdentityCountry.

@gab2020 , have one table with all identity and one all IdentityCountry. Do not join them with your table. Use only in the slicer.

 

how to create a table from exiting the column 

https://www.dropbox.com/s/op9lb78w9utdonz/Distinct%20from%20two%20Tables.pbix?dl=0

 

check how the new column has been created.

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

Hi @amitchandak , I have created the slicers as per your sharing.

Not able to slice the data though. Kindly refer to the details in below link.

https://www.dropbox.com/s/my4d2pz2pne3gom/test.pbix?dl=0

 

e.g. selected MY in the IdentityCountry Slicer and expecting rows 2 and 3 from table to be output but its not working as expected.

Thanks.

gab2020_0-1595988731618.png

 

@gab2020 , unable to open the file. It is saying I need a higher version. Higher than July 2020 🤔

Share with Power BI Enthusiasts: Full Power BI Video (20 Hours) YouTube
Microsoft Fabric Series 60+ Videos YouTube
Microsoft Fabric Hindi End to End YouTube

Hi @amitchandak , it's fine. Manage to get it working already. Thanks for your advise too. Much appreciated. 😀

Helpful resources

Announcements
November Power BI Update Carousel

Power BI Monthly Update - November 2025

Check out the November 2025 Power BI update to learn about new features.

Fabric Data Days Carousel

Fabric Data Days

Advance your Data & AI career with 50 days of live learning, contests, hands-on challenges, study groups & certifications and more!

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.

Top Solution Authors
Top Kudoed Authors