Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.
Register now!The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now! Learn more
Hey Guys,
Hope someone can help. I know I sound like a noob...but, I would like to filter one table with values from another table. I am setting up RLS that filters the tables based on the current user (Power BI Embedded into an app)
I have two tables Groups and UserHasGroups
Groups
| ID | GROUP_NAME |
UserHasGroups
| USER_ID | GROUP_ID |
UserHasGroups[GROUP_ID] = Groups[ID].
In the Roles, I have a DAX filter that filters the UserHasGroups to only display the groups for the current user:
[USER_ID]=
LOOKUPVALUE(
USER[ID],
USER[USERNAME],
USERNAME()
)
What I would like to accomplish is to thereafter filter the Groups table to only include IDs that exists in the filtered UserHasGroups table.
can anyone please help me with this?
Thanks.
1. please do not use USERNAME(), it behaves differently on the desktop and in the service. Use USERPRINCIPALNAME()
2. Normally this type of RLS is implemented through the data model (ie the UserHasGroups table sits upstream from the Groups table and filters it automatically). Is that something you can consider?
Thanks @lbendlin for your reply
I will consider using the USERPRINCIPALNAME().
The problem is, I have bridge tables and UserHasGroups is sitting on the many side of the relationship.
That is indeed a problem. What's the reason for that setup?
Its sure is. Quite a complex design that had to accomodate for method of provisioning entities in our App.
The Power BI Data Visualization World Championships is back! Get ahead of the game and start preparing now!
| User | Count |
|---|---|
| 14 | |
| 5 | |
| 5 | |
| 3 | |
| 3 |
| User | Count |
|---|---|
| 24 | |
| 10 | |
| 10 | |
| 6 | |
| 6 |