我有4张桌子
EMPLOYEE
(E#, NAME
),主键为E#
DRIVER
(E#, L#
),主键是E#
引用EMPLOYEE
TRIP
(T#, L#
),主键为T#
,外键L#
引用DRIVER
TRIPPT
(T#, PT#
)主键是T#
引用TRIP
我创建了一个函数,可以找到驱动程序执行的最长点的长度(pt#的总数)
到目前为止我的查询:
create or replace function LONGPT (DL# in TRIP.L#%type)
return TRIPPT.PT#%type
IS
TRIPPT# TRIPPT.PT#%type;
begin
select max (PT#)
into TRIPPT#
from TRIPPT
where T# in (select T#
from TRIP
where L# = DL#);
return nvl (TRIPPT#, 0);
end LONGPT;
如何执行选择查询以显示员工的NAME
LONGPT。不执行跳闸点的驱动程序名称也需要在查询中。
我试过了:
SELECT DRIVER.L# AS License_No, LONGTPT(TRIP.L#) AS "LONGEST POINT"
FROM DRIVER
LEFT OUTER JOIN TRIP on DRIVER.L# = TRIP.L#;
这只查询L#和LONGEST Point。
任何人都可以指导我如何在显示员工的NAME和我的函数LONGPT上执行select语句。
答案 0 :(得分:0)
这是我设法弄清楚的工作查询。
SELECT DISTINCT EMPLOYEE.NAME, LONGPT(TRIP.L#) AS "LONGEST Point"
FROM DRIVER Join EMPLOYEE ON DRIVER.E# = EMPLOYEE.E# LEFT OUTER JOIN
TRIP on DRIVER.L# = TRIP.L#;