当前位置:网站首页>BI技巧丨权限轴
BI技巧丨权限轴
2022-07-03 09:48:00 【PowerBI丨白茶】
BOSS:(愁眉苦脸)白茶呢?
同事:(推一推)醒醒,白茶,BOSS喊你!
白茶:(一脸懵)咋了,老板?
BOSS:(一脸嫌弃)白茶,有个需求,用户要求在同一个图表中,指标可以切换。
白茶:这个之前做过啊,就是动态指标啊!
BOSS:别急,还有,就是我们不同的用户,角色是不一样的,能不能让不同用户进来看到图表的坐标轴因人而异?
白茶:权限轴?
BOSS:是的!
白茶:OK,能搞!
BI报表在实际应用中,往往需要对报表权限进行配置,例如RLS权限、OLS权限、页面权限等等。
其实,除了这三种权限之外,还有一种特殊的权限需求。
一张BI报表,面对的用户有很多,而不同的用户角色是不一样的。很多时候,用户期望打开报表时,可以根据自己的角色,看到自己需要观测的维度。
那么在PowerBI中,如何去实现这样的需求呢?
先来看看本期的案例数据:
案例数据共计五张表。Date日期表,Product产品表,Store门店表,Access权限表,Sales销售事实表。
从Access权限表中可以看到,我们一共有三个用户,分别代表分店负责人、产品负责人、市场负责人,我们需要做到,根据用户的不同角色,自动适配对应的维度坐标轴。
将数据导入到PowerBI,模型关系如下图:
小伙伴们注意,Access这张表,不需要和其他表建立模型关系。
构建基础的度量值:
销售数量:
A.销售数量 =
SUM ( Fact_Sales[Quantity] )销售金额:
B.销售金额 =
SUMX ( 'Fact_Sales', [Quantity] * RELATED ( Dim_Product[Price] ) )构建指标切换的维度表:
添加动态切换度量值:
C.KPI =
IF ( SELECTEDVALUE ( Dim_KPI[Sort] ) = 1, [A.销售数量], [B.销售金额] )到这里,我们的准备工作就结束了,思考一下,下一步要如何达成权限轴的动态切换效果。
思考一下
1
2
3
......
权限动态轴需要完成两个条件:
1.需要有一张包含所有用户需求维度的表;
2.需要根据用户权限配置维度表的数据权限。
构建动态分析维度表:
新建一张表,输入如下代码:
Dim_Analysis =
VAR Store =
SELECTCOLUMNS (
ADDCOLUMNS ( DISTINCT ( 'Dim_Store'[StoreName] ), "Analysis", "1" ),
"Analysis", [Analysis],
"Display", [StoreName]
)
VAR ProductName =
SELECTCOLUMNS (
ADDCOLUMNS ( DISTINCT ( 'Dim_Product'[ProductName] ), "Analysis", "2" ),
"Analysis", [Analysis],
"Display", [ProductName]
)
VAR City =
SELECTCOLUMNS (
ADDCOLUMNS ( DISTINCT ( 'Dim_Store'[City] ), "Analysis", "3" ),
"Analysis", [Analysis],
"Display", [City]
)
RETURN
UNION ( Store, ProductName, City )结果如下:
这段代码,相当于把门店、产品、城市这三个维度强行组合生成一张新的表。
添加如下度量值:
D.AnalysisKPI =
VAR Store =
TREATAS ( VALUES ( 'Dim_Analysis'[Display] ), 'Dim_Store'[StoreName] )
VAR ProductName =
TREATAS ( VALUES ( 'Dim_Analysis'[Display] ), 'Dim_Product'[ProductName] )
VAR City =
TREATAS ( VALUES ( 'Dim_Analysis'[Display] ), 'Dim_Store'[City] )
VAR Analysis =
SELECTEDVALUE ( 'Dim_Analysis'[Analysis] )
RETURN
SWITCH (
TRUE (),
Analysis = "1", CALCULATE ( [C.KPI], Store ),
Analysis = "2", CALCULATE ( [C.KPI], ProductName ),
Analysis = "3", CALCULATE ( [C.KPI], City ),
BLANK ()
)效果如下:
白茶希望标题也可以根据用户的权限进行自动适配。
添加如下代码:
E.Title =
VAR T1 =
IF ( SELECTEDVALUE ( Dim_KPI[Sort] ) = 1, "Sales Volume", "Revenue" )
VAR T2 =
SELECTEDVALUE ( Dim_Analysis[Analysis] )
VAR T3 =
SWITCH (
TRUE (),
T2 = "1", "Store",
T2 = "2", "Product",
T2 = "3", "City",
"BaiCha"
)
RETURN
T1 & " Analysis By " & T3添加用户权限度量值:
度量值如下:
F.Access =
VAR UserAccess =
CALCULATETABLE (
VALUES ( Dim_Access[行权限] ),
'Dim_Access'[邮箱] = USERPRINCIPALNAME ()
)
VAR Access =
SELECTEDVALUE ( Dim_Analysis[Analysis] ) IN UserAccess
RETURN
Access在建模面板下,选择管理角色,输入角色“Access”,输入如下代码:
[F.Access]=True()结果如下:
美化一下报表,最终展示的效果如下图:
(BOSS:Nice!)
Demo文件在知识星球。
这里是白茶,一个PowerBI的初学者。
边栏推荐
- 英特尔13代酷睿旗舰曝光,单核5.5GHz
- 反正切熵(Arctangent entropy):2022.7月最新SCI论文
- Extern keyword
- My understanding of testing (summarized by senior testers)
- QT: QSS custom qtableview instance
- 10. Nacos source code construction
- Differences among norm, normalize and normalized in eigen
- In the middle of the year, I have prepared a small number of automated interview questions. Welcome to the self-test
- Stack, monotone stack, queue, monotone queue
- Redis notes 01: Introduction
猜你喜欢

Communication software development and Application

Comment réaliser des tests automatisés pour les tests logiciels embarqués?

How to realize automatic testing in embedded software testing?

redis那些事儿

2021 reading summary (continuously updating)

使用ML.NET+ONNX预训练模型整活B站经典《华强买瓜》

After 8 years of industry thinking, the test director has a deeper understanding of test thinking

I have been doing software testing for three years, and my salary is less than 20K. Today, I put forward my resignation

如何清理v$rman_backup_job_details视图 报错ORA-02030

8年测试工程师总结出来的《测试核心价值》与《0基础转行软件测试超全学习指南》
随机推荐
Activity and fragment lifecycle
英特尔13代酷睿旗舰曝光,单核5.5GHz
(二)进制
Internet Socket (非)阻塞write/read n个字节
今晚要修稿子準備發佈。但是,仍卡在這裡,也許你需要的是一個段子。
Qt:qss custom QSlider instance
Game test related tests a hero's skills (spring moves are asked more questions)
软件测试——Redis数据库
Inexplicable problems in the nesting of constraintlayout and relativelayout
封装一个koa分布式锁中间件来解决幂等或重复请求的问题
In the middle of the year, I have prepared a small number of automated interview questions. Welcome to the self-test
Commonly used discrete random distribution
QT: QSS custom qsplitter instance
glassfish org. h2.server. Shutdownhandler classnotfoundexception exception exception handling
10. Nacos source code construction
嵌入式软件测试怎么实现自动化测试?
Qt:qss custom qscrollbar instance
年中了,准备了少量的自动化面试题,欢迎来自测
Word line and bit line
【Proteus仿真】74HC154 四线转12线译码器组成的16路流水灯