不支持SQL Join表达式

时间:2014-06-21 02:06:39

标签: sql ms-access join left-join

以下是我的询问:

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。

1 个答案:

答案 0 :(得分:2)

你缺少一些别名。

用作表的每个内部查询必须被赋予别名,并且在加入它们时,您必须使用该别名,并且只能使用连接条件中的选定列。

例如,为这些行添加别名:

...
    ON D.DateID = AI.DateID) AS SOMETHING_1
  ON I.InfractionID = AI.InfractionID) AS SOMETHING_2