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

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Reply
planbitionbi
Frequent Visitor

Seguridad de nivel de fila con correo electrónico de usuario -> ID de usuario múltiple con el mismo correo electrónico para filtrar

¡Hola a todos!

He implementado con éxito la seguridad de nivel de fila utilizando la guía:

https://www.youtube.com/watch?v=Sge_g9hTXWE&feature=emb_logo&ab_channel=PragmaticWorks

Ahora el único problema es que puedo tener varios usuarios (userID) con la misma dirección de correo electrónico y mi filtro DAX en la tabla en la que he implementado RLS espera un singel UserID. ¿Cómo puedo cambiar esta fórmula DAX de una manera que varios USerID pueden ser la entrada del filtro.

DAX Formule en mi tabla CustomerStructure:

[ID] EN SELECTCOLUMNS(
FILTRO(
Security_User_CustomerStructure,
Security_User_CustomerStructure[PersonID] á LOOKUPVALUE(Security_Users[PersonID], Security_Users[Email], USERNAME() )
),
"ID", [CustomerStructureID]
)

Pantallas de impresión:

planbitionbi_0-1610442260722.pngplanbitionbi_1-1610442287192.png

1 ACCEPTED SOLUTION

No @planbitionbi ,

Consulte la siguiente medida:

[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]
        )

Si este post ayuda, entonces considera Aceptarlo como la solución para ayudar a los otros miembros a encontrarlo más rápidamente.

Saludos

Dedmon Dai

View solution in original post

3 REPLIES 3
Syndicate_Admin
Administrator
Administrator

¡Hola!

Muchas gracias por sus comentarios. Desafortunadamente está lanzando un error como el de abajo. ¿Puedes ver por qué está mal? Algo con la cláusula IN:

planbitionbi_0-1610615667143.png

No @planbitionbi ,

Consulte la siguiente medida:

[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]
        )

Si este post ayuda, entonces considera Aceptarlo como la solución para ayudar a los otros miembros a encontrarlo más rápidamente.

Saludos

Dedmon Dai

Syndicate_Admin
Administrator
Administrator

No @planbitionbi ,

Le sugiero que utilice USERPRINCIPALNAME ( ) en lugar de USERNAME() y puede cambiar el dax a :

[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]
)

Si este post ayuda, entonces considera Aceptarlo como la solución para ayudar a los otros miembros a encontrarlo más rápidamente.

Saludos

Dedmon Dai

Helpful resources

Announcements
Sept PBI Carousel

Power BI Monthly Update - September 2024

Check out the September 2024 Power BI update to learn about new features.

September Hackathon Carousel

Microsoft Fabric & AI Learning Hackathon

Learn from experts, get hands-on experience, and win awesome prizes.

Sept NL Carousel

Fabric Community Update - September 2024

Find out what's new and trending in the Fabric Community.

Top Solution Authors