ORA-00904:分组子句后的标识符无效

时间:2016-02-02 14:10:28

标签: sql oracle group-by ora-00904

我试图运行这个选择命令:

select
    r.id,
    r.trip_reason,
    r.status, 
    to_char(trunc(r.trip_date),'DD/MM/YYYY') AS trip_date,
    c.country, count(a.request_id)           AS AZ_Travelers,
    t.travel_by, 
    tt.type,
    r.trip_city,
    r.nr_non_az,
    initcap(e.first_name || ' ' || e.last_name) AS requestor,
    r.requestor_id

 from et_request r, et_country c, et_travel_by t,
      et_trip_type tt, hr_dwh.pm_employees e, et_approval a     

where nvl(r.archived,0)<>1
  and trunc(r.trip_date) >= trunc(sysdate)
  and r.requestor_id = e.empl_id
  and r.id = a.request_id
  and r.trip_country_code = c.id
  and r.travel_by_id = t.id
  and r.trip_type_id = tt.id

group by r.id, r.trip_reason, r.status, trip_date, c.country, AZ_Travelers,
         t.travel_by, tt.type, r.trip_city, r.nr_non_az, requestor, r.requestor_id
order by r.trip_date;

但是,我收到以下错误:

ORA-00904: "REQUESTOR": invalid identifier

我已经注意使用group by子句中的每个表格字段但我收到此错误。关于那个的任何领导?

1 个答案:

答案 0 :(得分:3)

数据库没有名为requestor的列 - 此时,它只是一个标签,你告诉它给结果集中的某些东西 - 它还没有生成它因此,当它在查询中遇到该名称时,不知道如何处理。

您可以按该计算列的组件进行分组,例如将requestor语句中的GROUP BY替换为e.first_name, e.last_name