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

Be one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now

Reply
Shawn_Eary
Advocate IV
Advocate IV

Filter Table by Username Without Row Level Security

I have a table named studentSuccess that looks something like this (Data is Not Actual):

 

IdrowUserNameCreated min
GPA
graduatedNot
Graduated
currentUserName
(Measure)
6jeffATfake.zzz3/2/2020  10:202.4100100shawnATfake.zzz
5shawnATfake.zzz3/2/2020  8:203.91955shawnATfake.zzz
4jdoeATfake.zzz3/2/2020 7:200.220180shawnATfake.zzz
3sdowATfake.zzz2/18/2020 15:231.860140shawnATfake.zzz
2shawnATfake.zzz2/11/2020 16:501.140160shawnATfake.zzz
1jeffATfake.zzz2/10/2020 16:503.819010shawnATfake.zzz

 

All colums correspond to a SharePoint List except for the currentUserName column which is a Measure that is set via the following DAX code:

currentUserName = USERPRINCIPALNAME()

I am able to display the table in various Power BI visualizations, but I want to filter them so the current user only sees the rows that match her/his username. I do not want to use Row Level Security for this.
 
In the example above, shawnATfake.zzz is the currently logged in user; therefore, his visualizations should only display rows with Id values of 6, 5 and 2.

To achieve this, I thought I could create a new measure named IsCurrentUser for my studentSuccess table with the following DAX code:
IsCurrentUser = 'studentSuccess'[rowUserName] = USERPRINCIPALNAME()

I was then going to set a static filter on all visualizations to only display the row when IsCurrentUser is True.

Unfortunately, when I try to create the above measure, I get an error:
"A single value for column 'rowUserName' in table 'studentSuccess' cannot be determined.  This can happen when a measure formula refers to a column that contains many values without specifying an aggregation such as min, max, count, or sum to get a single result."

So then I tried to create a calculated column with this DAX code:
isCurrentUser2 = 'studentSuccess'[rowUserName] = USERPRINCIPALNAME()

When I try that, I get a different error:

CUSTOMDATA, USERNAME, USERCULTURE and USERPRINCIPALNAME functions are not supported in calculated tables/columns. These functions may only be used in Measures or in the AllowedRowsExpression.


So either way I go, I get an error.  I want to filter the results to only the current user without using Row Level Security (RSL).  Is there an easy way to do that?


2 ACCEPTED SOLUTIONS
Shawn_Eary
Advocate IV
Advocate IV

I found the answer here:
https://community.powerbi.com/t5/Desktop/Error-on-using-UserName-function-in-custom-table/m-p/344243...
v-jiascu-msft posted the answer.  I just had a hard time understanding what v-jiascu-msft was saying. 

Apparently, I should not try to use a calculated column, but instead use a measure.  When I use a measure, however, I have to use a MIN or MAX function in the way that Dale (v-jiascu-msft) suggests.  

I would argue that for situations like these where we want to avoid naked columns, we should maybe also have an IDENTITY function to go along with MIN and MAX.  Maybe we could use the IDENTITY function whenever either MAX or MIN would work and it doesn't matter.  Seems like using the IDENTITY function in those situations might make the code easier to read.

DAX serious confuses me.


 

View solution in original post

v-shex-msft
Community Support
Community Support

Hi @Shawn_Eary,

The measure is an expression used to calculate based on corresponding row content. Its result will changes if row contents change.
You can't direct use table or columns in its expression except you enable aggregate functions or filters to the summary result value. (it calculate on filtered summarize values instead direct calculate on table fields)

For the calculated column, it is a field stored on table so its calculate range is the whole table and requires calculating the result when the data model table updated. (BTW, you can directly use column fields to calculate in its expression)

You can take a look at the following link to know more about the difference between the calculated column and measure:

Calculated Columns and Measures in DAX 

Username and other functions listed in the notification messages, they are extracted from AS tabular instance features/information. For these special functions, I think they are limited to use on minimum 'row' level(might be security reasons) and not allow to use in column and table level.

Regards,

Xiaoxin Sheng

 

Community Support Team _ Xiaoxin
If this post helps, please consider accept as solution to help other members find it more quickly.

View solution in original post

9 REPLIES 9
Syndicate_Admin
Administrator
Administrator

Hello.

Did you find a solution? I have also tried to use the USERPRINCIPALNAME() to filter information that can be seen by the logged-in user and all the options I have tried failed.

It would be good if they enabled a solution for this, since there are many of us who need to filter by user without RSL.

It is possible to filter a visual (table, slicer, for the others I haven't tried) using userprincipalname() without using RLS. You have to use userprincipalname() within a measure and use that measure in the filter pane to filter the visual you want to filter. Not every measure works so of course you have to be a little bit clever when you build it.

cv77
Helper I
Helper I

Shawn, can you tell me how you set your table column to contain USERPRINCIPALNAME() ?  When I try to do that I get a message that the UPN can't be used in a column, only in a measure.  Same as you, I have the requirement to filter data using username without using RLS, and am trying to figure out how to do that.  I can put the UPN (or username()) in a measure, but can't filter my report pages using a measure.  I think that if I could reference the username in a column I can compare the current user with our usertable, which in turn contains IDs which are used to filter subsequent data on the reports.  

 

Thank you for any suggestions. 


@cv77 wrote:

Shawn, can you tell me how you set your table column to contain USERPRINCIPALNAME() ?  When I try to do that I get a message that the UPN can't be used in a column, only in a measure. 


@cv77 - I'm very sorry.  I wasn't able to look at this last night.  I think you are right.  I am only able to use the USERPRINCIPALNAME() function inside a Measure.  It doesn't work for me in a Calculated Column.  I wanted it to work in a Calculated Column, but I could never get that to happen, so I wound up using a very convoluted "half-broken" workaround that employed Measures instead of Calculated Columns.

I'm sorry I don't remember the details on this.  I've since worked on other projects.

Got it, thank you for your response Shawn.

v-shex-msft
Community Support
Community Support

Hi @Shawn_Eary,

The measure is an expression used to calculate based on corresponding row content. Its result will changes if row contents change.
You can't direct use table or columns in its expression except you enable aggregate functions or filters to the summary result value. (it calculate on filtered summarize values instead direct calculate on table fields)

For the calculated column, it is a field stored on table so its calculate range is the whole table and requires calculating the result when the data model table updated. (BTW, you can directly use column fields to calculate in its expression)

You can take a look at the following link to know more about the difference between the calculated column and measure:

Calculated Columns and Measures in DAX 

Username and other functions listed in the notification messages, they are extracted from AS tabular instance features/information. For these special functions, I think they are limited to use on minimum 'row' level(might be security reasons) and not allow to use in column and table level.

Regards,

Xiaoxin Sheng

 

Community Support Team _ Xiaoxin
If this post helps, please consider accept as solution to help other members find it more quickly.
Shawn_Eary
Advocate IV
Advocate IV

I found the answer here:
https://community.powerbi.com/t5/Desktop/Error-on-using-UserName-function-in-custom-table/m-p/344243...
v-jiascu-msft posted the answer.  I just had a hard time understanding what v-jiascu-msft was saying. 

Apparently, I should not try to use a calculated column, but instead use a measure.  When I use a measure, however, I have to use a MIN or MAX function in the way that Dale (v-jiascu-msft) suggests.  

I would argue that for situations like these where we want to avoid naked columns, we should maybe also have an IDENTITY function to go along with MIN and MAX.  Maybe we could use the IDENTITY function whenever either MAX or MIN would work and it doesn't matter.  Seems like using the IDENTITY function in those situations might make the code easier to read.

DAX serious confuses me.


 


@Shawn_Eary wrote:

I found the answer here:
https://community.powerbi.com/t5/Desktop/Error-on-using-UserName-function-in-custom-table/m-p/344243...
v-jiascu-msft posted the answer.  I just had a hard time understanding what v-jiascu-msft was saying.


This trick is working for me when I use the Stacked Column chart visualization, but strangely, I can't use the Pie Chart visualization because when I add the isCurrentUser Measure to my Pie Chart visualization, the "Show items when the value:" DropDowns are strangely disabled.  That isn't a big deal though because I can simply use the Stacked Column chart since it essentially displays the same information when I set rowUsername as the axis and filter to only select rows when isCurrentUser = 1.  Unfortunately, I have a different issue now...

When I filter my Stacked Column chart to only display results when (isCurrentUser = 1), I get exactly one Stacked Bar that correponds to the current user.  This is close to what I want, unfortunately, that Stacked Bar displays the summation of all graduated and notGraduated values for that current user.  I don't want the summation, I simply want the latest value for the current user.  To achieve that, I try to add a Top N Latest 1 query on the Created Field.  Unfortunately, as soon as I apply that, my Stacked Bar chart dissappears because (in my particular case) the current user is not the the user that last submitted an entry to the studentSucess Table.

I need my (Top N Lastest 1) and (CurrentUser is 1) filters to work together so the Stacked column chart shows data from the latest row for the current user regardless wheither or not the current user is the one who created the latest entry.

 

I came close to getting a DAX forumula to resolve this but I kept getting hiccups.  My present resolution is to simply use a UNIQUE constraint to only allow one row per user until I am more familiar with Power BI.

 

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.