我必须返回一个程序,它会在表格中显示缺少的数据。
CREATE OR REPLACE PROCEDURE GETEMPLOYEE_INFO
(
P_CPNCOD in varchar2,
P_PAYDAT in date,
P_PAYTYP in varchar2,
P_ERV out varchar2)
is
R_DI_FILLODINF NUMBER(20);
BEGIN
FOR i IN (SELECT * FROM DI_ELEMOD)
LOOP
SELECT COUNT(*) INTO R_DI_FILLODINF
FROM DI_FILLODINF
WHERE P_CPNCOD=i.CPNCOD and
P_PAYDAT=i.PAYDAT and
P_PAYTYP=i.PAYTYP ;
if nvl(R_DI_FILLODINF,0)<=0
then
dbms_output.put_line ('missing data : ' || i.CPNCOD || i.PAYDAT || i.PAYTYP );
end if;
end loop;
EXCEPTION
WHEN OTHERS THEN NULL;
end;
/
但现在我的问题是,如果我把日期'01 -JUN-12'比输出显示缺少数据但仅显示2012年。请帮助
非常感谢
DECLARE
V_INSTY DI_FILLODINF.INSTYP%TYPE;
BEGIN
GETEMPLOYEE_INFO ('CO','01-JUN-12','D',V_INSTY);
END;
/
答案 0 :(得分:1)
如果我理解你的话,那么你需要做的就是在你的外部查询中只选择正确年份的值:
SELECT * FROM DI_ELEMOD
WHERE PAYDAT >= trunc(P_PAYDAT, 'yyyy')
AND PAYDAT <= trunc(add_months(P_PAYDAT,12),'yyyy')-1
答案 1 :(得分:0)
如果您只想发送特定日期的年份,您可以使用子串或更多来使用裁剪数据。