加入表查询
Join query on tables
我 运行 2 个关于 table 的查询,它们在 "Where" 子句中是相同的,所以我相信它们应该 return 相同的值。
我的第一个查询是:
select B.NameDastgahID, B.ZarfiateHamleBar, B.SherkateSazande, B.BisimHF, B.KanalBisimKhodroyi, B.ShomarePelak, B1.NameDastgahTitle, B2.NameKhodroTitle, B3.NoeKhodroTitle, B4.KarbarieKhodroTitle, B5.ShahreKhodroTitle, B6.cheraghgardanValue, B7.bisimHFTitle
from dw.bohran_fct_etelaatenavegankhodroyi B
INNER JOIN dw.excel_dim_namedastgah B1 using (NameDastgahID)
INNER JOIN dw.excel_dim_namekhodro B2 using (NameKhodroID)
INNER JOIN dw.excel_dim_noekhodro B3 using (NoeNavganID)
INNER JOIN dw.excel_dim_karbariekhodro B4 using (KarbariID)
INNER JOIN dw.excel_dim_shahrekhodro B5 using (ShahrID)
INNER JOIN dw.excel_dim_cheraghgardan B6 using (CheraghGardan)
INNER JOIN dw.excel_dim_bisimhf B7 using (bisimHF)
where NameKhodroID = '630'
它 return 有 61 行。
第二个查询:
select *
from dw.bohran_fct_etelaatenavegankhodroyi
where NameKhodroID = '630'
这 returns 122 行。
第二个查询总是比第一个查询多 return 行,即使我更改了条件。有什么想法吗??
我建议一次删除一个 JOIN
,直到找到导致此问题的那个。
这并不奇怪,这是正常行为,您正在连接 7 个不同的表,如果这 7 个表的任何条件都不正确,那么记录将被过滤!
我 运行 2 个关于 table 的查询,它们在 "Where" 子句中是相同的,所以我相信它们应该 return 相同的值。
我的第一个查询是:
select B.NameDastgahID, B.ZarfiateHamleBar, B.SherkateSazande, B.BisimHF, B.KanalBisimKhodroyi, B.ShomarePelak, B1.NameDastgahTitle, B2.NameKhodroTitle, B3.NoeKhodroTitle, B4.KarbarieKhodroTitle, B5.ShahreKhodroTitle, B6.cheraghgardanValue, B7.bisimHFTitle
from dw.bohran_fct_etelaatenavegankhodroyi B
INNER JOIN dw.excel_dim_namedastgah B1 using (NameDastgahID)
INNER JOIN dw.excel_dim_namekhodro B2 using (NameKhodroID)
INNER JOIN dw.excel_dim_noekhodro B3 using (NoeNavganID)
INNER JOIN dw.excel_dim_karbariekhodro B4 using (KarbariID)
INNER JOIN dw.excel_dim_shahrekhodro B5 using (ShahrID)
INNER JOIN dw.excel_dim_cheraghgardan B6 using (CheraghGardan)
INNER JOIN dw.excel_dim_bisimhf B7 using (bisimHF)
where NameKhodroID = '630'
它 return 有 61 行。
第二个查询:
select *
from dw.bohran_fct_etelaatenavegankhodroyi
where NameKhodroID = '630'
这 returns 122 行。
第二个查询总是比第一个查询多 return 行,即使我更改了条件。有什么想法吗??
我建议一次删除一个 JOIN
,直到找到导致此问题的那个。
这并不奇怪,这是正常行为,您正在连接 7 个不同的表,如果这 7 个表的任何条件都不正确,那么记录将被过滤!