我试图运行这个选择命令:
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
子句中的每个表格字段但我收到此错误。关于那个的任何领导?
答案 0 :(得分:3)
数据库没有名为requestor
的列 - 此时,它只是一个标签,你告诉它给结果集中的某些东西 - 它还没有生成它因此,当它在查询中遇到该名称时,不知道如何处理。
您可以按该计算列的组件进行分组,例如将requestor
语句中的GROUP BY
替换为e.first_name, e.last_name
。