2

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

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 语句中使用过别名,所以我很困惑为什么我会收到错误。在这种情况下它的工作方式是否不同?

4

2 回答 2

6

从文档(强调添加):

您可以使用列别名 ,c_alias来标记选择列表中紧接在前面的表达式,以便以新标题显示该列。别名在查询期间有效地重命名选择列表项。别名可以在 ORDER BY子句中使用,但不能在查询中的其他子句中使用。

所以你不能在where子句中引用别名,此时你有:

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

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

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

于 2013-09-30T15:14:53.067 回答
5

Oracle 按以下顺序运行选择查询:

  1. FROM 子句
  2. WHERE 子句
  3. GROUP BY 子句
  4. HAVING 子句
  5. 选择子句
  6. ORDER BY 子句

综合以上可以看到,当你在 WHERE 部分时,别名还没有被创建。如果您想使用 SELECT 部分的结果,可以通过如下修改查询来实现:

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

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

希望这可以帮助!:)

于 2013-09-30T15:25:30.200 回答