3

我已经阅读了其他缺少的右括号问题,但没有找到我的问题的答案。我认为这是一个语法错误,在结束之前切断了一些东西(我不是一个真正的 Oracle 人),但我不知道它在哪里。该查询应该提取客户 ID,并且该客户最近一年有记录。参数是客户 ID 号(按地区唯一,但与组织不同)、地区和被搜索的年份。如果该地区的检索年份没有记录,则不应返回任何记录。

SELECT DISTINCT CUSTOMER.CUSTOMER_ID_ALT, tblMaxYear.maxYear 
FROM CUSTOMER CROSS JOIN 
  (SELECT to_char(Max(tblYr.FISCAL_YEAR), 'YYYY') AS maxYear     
  FROM CUSTOMER AS tblYr 
  WHERE tblYr.DISTRICT_KEY= :district
      AND tblYr.CUSTOMER_ID= :cust) tblMaxYear 
WHERE CUSTOMER.DISTRICT_KEY=:district
   AND CUSTOMER.CUSTOMER_ID= :cust
   AND to_char(CUSTOMER.FISCAL_YEAR, 'YYYY') = :prmYear
4

1 回答 1

4

删除 AS:

FROM CUSTOMER AS tblYr

AS 可用于列别名,不能用于表别名

于 2012-01-09T17:37:52.023 回答