以下是我的询问:
SELECT
UT.AgentName AS [Agent Name],
UT.TeamName AS Team,
Format(Now(),"Short Date") AS [As Of],
Sum(I.RegPointValue) AS Points
FROM
(SELECT
UU.AgentID,
(Nz(UU.LastName,'')+", "+Nz(UU.FirstName,'')) AS AgentName ,
TT.TeamName
FROM
Users AS UU
INNER JOIN
Teams AS TT
ON UU.TeamID = TT.TeamID) AS UT
LEFT JOIN
(InfractionTypes AS I
INNER JOIN
(DateCodes AS D
INNER JOIN
AquiredInfractions AS AI
ON D.DateID = AI.DateID)
ON I.InfractionID = AI.InfractionID)
ON UT.AgentID = AI.AgentID
WHERE (((D.DateValue)>=#4/1/2014#))
GROUP BY UT.TeamName, UT.AgentName, I.RegPointValue;
这样做总结了一个人根据他们收到的出勤违规所得到的所有要点。如果我将LEFT JOIN
更改为INNER JOIN
,则查询有效但仅返回已收到出勤违规行为的人的姓名。但我想要的是它返回所有人的名字,如果他们没有收到任何人,他们的积分为0。
我尝试保存或执行时收到的错误是Join expression not supported
。我一直试图通过搞乱连接的顺序让这个工作在最后几个小时工作,但无济于事。使用MS-Access 2013。
答案 0 :(得分:2)
你缺少一些别名。
用作表的每个内部查询必须被赋予别名,并且在加入它们时,您必须使用该别名,并且只能使用连接条件中的选定列。
例如,为这些行添加别名:
...
ON D.DateID = AI.DateID) AS SOMETHING_1
ON I.InfractionID = AI.InfractionID) AS SOMETHING_2
等