ORA-00904 解码别名上的标识符无效



当我尝试在select语句中使用decode的别名时,我遇到了标题中所述的错误。这是代码:

SELECT DISTINCT rl.complaint_date, 
                  decode(rl.judgement_date,null,rl.complaint_amt,rl.judgement_amt) as account_amt, 
                  rl.date_served1, 
                  rl.date_served2,
                  rl.judgement_date,         
                  rl.skip_locate,
                  rl.case_no,
                  lcc.bal_range_min, 
                  lcc.bal_range_max, 
                  lcc.cost_range_min, 
                  lcc.cost_range_max, 
                  lcc.court,
                  lcc.county AS lcc_county,
                  ah.ACCOUNT, 
                  ah.transaction_code, 
                  ah.transaction_date, 
                  ah.rule_id, 
                  ah.amount, 
                  ah.description,                    
                  r.state, 
                  r.zip_code, 
                  z.county AS ah_county,
                  z.county_2,
                  z.county_3,
                  z.county_4
  FROM legal_address_skip las,
       racctrel r, 
       ziplist z, 
       legal_court_cost lcc, 
       racctlgl rl,
       legal_transaction_review ah
  WHERE ah.ACCOUNT = rl.ACCOUNT
  AND ah.ACCOUNT = las.ACCOUNT(+)
  AND ah.ACCOUNT = r.ACCOUNT
  AND nvl(lpad(substr(r.zip_code,0,instr(r.zip_code,'-')-1),5,0), substr(r.zip_code,1,5)) = z.zip 
  AND r.state = lcc.state
  AND (REPLACE(lcc.county,' ','') = REPLACE(upper(z.county),' ','') 
       OR REPLACE(lcc.county,' ','') = REPLACE(upper(z.county_2),' ','')
       OR REPLACE(lcc.county,' ','') = REPLACE(upper(z.county_3),' ','')
       OR REPLACE(lcc.county,' ','') = REPLACE(upper(z.county_4),' ',''))
  AND lcc.transaction_code = ah.transaction_code
  AND lcc.transaction_code = 1
  AND lcc.end_date IS NULL
  AND ah.amount NOT BETWEEN lcc.cost_range_min AND lcc.cost_range_max
  AND (account_amt NOT BETWEEN lcc.bal_range_min AND lcc.bal_range_max
      OR lcc.bal_range_min - account_amt NOT BETWEEN 0 AND 500)
  ORDER BY CASE 
           WHEN ah.amount NOT BETWEEN lcc.cost_range_min AND lcc.cost_range_max THEN 1
           WHEN ah.amount BETWEEN lcc.cost_range_min AND lcc.cost_range_max THEN 2 END, ah.amount;

我以前在 select 语句中使用过别名,所以我对为什么我会收到错误感到困惑。在这种情况下,它的工作方式是否不同?

来自文档(强调添加):

您可以使用列别名 c_alias 来标记立即 选择列表中的前置表达式,以便列 以新标题显示。别名有效地重命名了选择 查询持续时间的列表项。别名可用于 ORDER BY子句,但不是查询中的其他子句。

因此,您不能引用 where 子句中的别名,目前您有:

...
AND (account_amt NOT BETWEEN ...
...

此时别名无效,因此它在其中一个表中查找具有该名称的列,但找不到。不过在order by里还好。

您需要将别名替换为重复的 decode 语句,或者可能使用子查询,然后在外部查询的 where 子句中引用别名,但这最终可能会降低效率,具体取决于其他条件的选择性。

Oracle 按

以下顺序运行选择查询:

  1. 从条款
  2. WHERE 子句
  3. 分组依据子句
  4. 有条款
  5. 选择子句
  6. 排序依据条款

基于上述内容,您可以看到,当您在 WHERE 部分中时,别名尚未创建。如果要使用 SELECT 部分的结果,可以通过修改查询来实现,如下所示:

WITH q AS 
(
-- Your query without the extra AND
)
SELECT *
FROM q
WHERE --put your check here

这样,当您到达 WHERE 部分时,您就已经有了可用的别名。

希望这有帮助! :)

最新更新