Don't miss your chance to take the Fabric Data Engineer (DP-700) exam on us!
Learn moreNext up in the FabCon + SQLCon recap series: The roadmap for Microsoft SQL and Maximizing Developer experiences in Fabric. All sessions are available on-demand after the live show. Register now
Hi all!
I have succesfully implemented row level security using the guide:
https://www.youtube.com/watch?v=Sge_g9hTXWE&feature=emb_logo&ab_channel=PragmaticWorks
Now the only issue is that I can have multiple users (userID's) with the same email adress and my DAX Filter on the table I have implemented RLS on expects a singel UserID. How can I change this DAX Formula in a way that multiple USerID's can be the input of the filter.
DAX Formule on my CustomerStructure table:
[ID] IN SELECTCOLUMNS(
FILTER(
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID] = LOOKUPVALUE(Security_Users[PersonID], Security_Users[Email], USERNAME() )
),
"ID", [CustomerStructureID]
)
Printscreens:
Solved! Go to Solution.
Hi @planbitionbi ,
Please refer to the following measure:
[ID]
IN SELECTCOLUMNS (
FILTER (
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID]
IN CALCULATETABLE (
VALUES ( Security_Users[PersonID] ),
FILTER ( Security_Users, Security_Users[Email] = USERPRINCIPALNAME () )
)
),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
Hi!
Thanks a lot for your feedback. Unfortunately it's throwing an error like below. Can you see why it's wrong? Something with the IN clause:
Hi @planbitionbi ,
Please refer to the following measure:
[ID]
IN SELECTCOLUMNS (
FILTER (
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID]
IN CALCULATETABLE (
VALUES ( Security_Users[PersonID] ),
FILTER ( Security_Users, Security_Users[Email] = USERPRINCIPALNAME () )
)
),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
Hi @planbitionbi ,
I suggest you use USERPRINCIPALNAME ( ) instead of USERNAME() and you can change the dax to :
[ID] IN SELECTCOLUMNS(
FILTER(
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID] IN CALCULATETABLE(VALUES(Security_Users[PersonID]),FILTER(Security_Users,Security_Users[Email] = USERPRINCIPALNAME())),
"ID", [CustomerStructureID]
)
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Best Regards,
Dedmon Dai
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.
A new Power BI DataViz World Championship is coming this June! Don't miss out on submitting your entry.
Share feedback directly with Fabric product managers, participate in targeted research studies and influence the Fabric roadmap.
| User | Count |
|---|---|
| 47 | |
| 44 | |
| 40 | |
| 18 | |
| 18 |
| User | Count |
|---|---|
| 70 | |
| 68 | |
| 33 | |
| 32 | |
| 32 |