我正在更新使用旧外部连接的旧建筑的查询(= *和* =)。我有3个表,我需要包括在一个外部联接。左外部连接3表
原来的查询是:
SELECT s.SkillID ,
NULL AS Signature ,
NULL AS DPL ,
CASE WHEN ISNULL(ds.DPL, dg.DPL) IS NULL
THEN p.ScaleTo - p.ScaleFrom + 1
ELSE ISNULL(ds.DPL, dg.DPL)
END AS DefaultDPL
FROM tbJobs j ,
tbSkills s
INNER JOIN tbSkillGroups sg ON s.SkillGroupID = sg.SkillGroupID ,
tbPerfScales p ,
tbDPLs ds ,
tbDPLs dg
WHERE j.JobID = 866
AND (ds.LevelID=*j.LevelID
AND ds.IDType = 1
AND ds.GroupOrSkillID=*s.SkillID
)
AND (dg.LevelID=*j.LevelID
AND dg.IDType = 0
AND dg.GroupOrSkillID=*sg.SkillGroupID
)
AND ((s.PerfScaleID IS NOT NULL
AND p.PerfScaleID = s.PerfScaleID
)
OR (s.PerfScaleID IS NULL
AND p.PerfScaleID = sg.PerfScaleID
)
)
我做:
SELECT s.SkillID ,
NULL AS Signature ,
NULL AS DPL ,
CASE WHEN ISNULL(ds.DPL, dg.DPL) IS NULL
THEN p.ScaleTo - p.ScaleFrom + 1
ELSE ISNULL(ds.DPL, dg.DPL)
END AS DefaultDPL
FROM tbPerfScales p ,
tbSkills s
INNER JOIN tbSkillGroups sg ON s.SkillGroupID = sg.SkillGroupID ,
tbJobs j
LEFT OUTER JOIN tbDPLs ds ON j.LevelID = ds.LevelID
AND s.SkillID = ds.GroupOrSkillID
LEFT OUTER JOIN tbDPLs dg ON j.LevelID = dg.LevelID
AND sg.SkillGroupID = dg.GroupOrSkillID
WHERE j.JobID = 866
AND ds.IDType = 1
AND dg.IDType = 0
AND ((s.PerfScaleID IS NOT NULL
AND p.PerfScaleID = s.PerfScaleID
)
OR (s.PerfScaleID IS NULL
AND p.PerfScaleID = sg.PerfScaleID
)
)
出于某种原因,我得到的错误:
The multi-part identifier "s.SkillID" could not be bound.
我知道是在这部分:
tbJobs j
LEFT OUTER JOIN tbDPLs ds ON j.LevelID = ds.LevelID
AND s.SkillID = ds.GroupOrSkillID
我不知道我在做什么错。
感谢任何帮助。 何塞
Yopu可能会发现wehn你这样做是因为外部的连接,您已经diffeernt结果比过去隐式语法在许多情况下都会产生不正确的结果,即使早于SQL Server 2000也是如此。因此,您正在修复的每个查询都可能不正确。你可能会得到坏结果混合implict和显式语法,你必须转换所有连接以获得正确的结果。 – HLGEM
这对某些情况可能是正确的,这就是为什么我要对它们进行大量测试以确保它们产生准确的结果。谢谢你的提示。 – JRGuay