[英]How to join 2 tables in Power BI with condition involving a 3rd table
我有 3 个表,公司、地址和 C_detail。 我需要从 C_detail 表中计算有多少家具有某个 C_ID 的公司。 但是存在的关系是 Company(CompanyID)=Address(CompanyID), Address(CountryID)=C_detail(CountryID)。 确切地说,我需要将此 sql 转换为 Power BI。
SELECT COUNT (*)
FROM Company a
JOIN Address b ON a.CompanyID = b.CompanyID
WHERE b.CountryID IN ( SELECT CountryID from C_detail WHERE C_ID = '1')
我如何使用来自不同表的应用条件连接表? 感谢并注意,我实际上对 DAX 很陌生,因此非常感谢对此的非常明确的解释。
最好的方法是在 powerBI 中创建这 3 个表之间的关系(将过滤器设置为双向):
Company to Address on CompanyID
Address to C_detail on CountryID
然后您可以创建一个简单的度量COUNT(Company[CompanyID])
并使用带有C_ID
值的切片器
如果您不想或无法创建关系,您可能可以通过以下措施获得类似的结果:
CompanyCount=
VAR tbl =
SELECTCOLUMNS (
FILTER (
SUMMARIZE (
'Address',
'Address'[CompanyID],
"valid",
CALCULATE (
COUNTROWS ( 'Address' ),
TREATAS ( VALUES ( 'Detail'[CountryID] ), 'Address'[CountryID] )
)
),
[valid] > 0
),
"CompanyID", 'Address'[CompanyID]
)
RETURN
CALCULATE ( COUNTROWS ( 'Company' ), TREATAS ( tbl, 'Company'[CompanyID] ) )
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.