On numerous occasions, I’ve been asked if it’s possible to create separate views of the same dashboard dependent on a user’s Power BI credentials? This is possible through Power BI’s Row-level security (RLS). With RLS we are applying security on the underlying data of the dashboard, so when we open the dashboard, Power BI will first check and apply the RLS on the data, and then only will it populate the visuals in the reports.
Disclaimer: This Blog was written in 2016, for an updated version of RLS, please visit our most recent blog: https://databear.com/row-level-security-with-powerbi/
Power BI Row Level Security.
Let’s take a look at a simple demo. In this scenario, we have a report and a dashboard that contains data from different countries, and when users open the Power BI dashboard they should only see data from the country applicable to them.
First step:
We will obtain our data from SQL Server via the Power BI Desktop import mode as shown below:
Note: DirectQuery is also supported for SQL Server. For simplicity, we are selecting import mode for this demo.
For my sample report, I am using NorthWind sales data.
After designing a sample report in Power BI Desktop, as seen below, the report shows data for all countries:
After setting up the Row-level security, a user should only see data for the USA when logging in:
Second Step:
Publish (upload) the Power BI report to Power BI service and apply the required security using a DAX expression. Once the report has been uploaded, we will have access to the dataset of our sample report, RLS_Report.pbix. From here, select the ‘Security’ option of this dataset.
Steps:
Go to Datasets > Find your dataset (RLS_Report) > click the ellipsis ( … ) > select Security
After selecting ‘Security’, a new window will open, follow the steps to create a role and add members to it, then provide the security rules, as follows:
Steps:
security > create a role
> select continue from the next window
> Provide a name for the new role created > select Members tab > add a member to this role by typing their name > click Add > Save
> now go to Rules tab > select the table > then provide the DAX filter expression > Save
We are using a simple DAX expression:
[Country]=”USA”
For the role “USA_Users” all members in this role will only have rows that contain “USA” in the country column.
Third Step:
Testing the applied security:
We can test the Row-level security by clicking on the ellipsis (…) next to the role name and click ‘Test data as role’. From there we can verify that the rules are correct. As seen below, we have a report displaying data for the USA only.
When users in the group signed in, they will only see the data as depicted above. A very useful feature in Power BI. This concludes our Power BI tip, using Power BI RLS.
To learn more about Power BI, sign up for our training program.
Hi there! Someone in my Myspace group shared this site with us
so I came to give it a look. I’m definitely enjoying the information.
I’m bookmarking and will be tweeting this to my followers!
Wonderful blog and amazing style and design.
Hi Jack, thanks for the comments. Glad you like the blog ;)
Wasn’t aware MySpace is still active…
Hello Johann,
Is there a way to apply sort by order on the these row level security that we create here? not on dashboards or reports while we create roles at particular time ?
Any suggestions or advise is appreciated.
Thanks,
Firdous
Hi Firdous,
I not sure what exactly you are asking here. Please elaborate on this.
Definitely, what a splendid website and enlightening posts, I surely will bookmark your site.Best Regards!