嘿嘿,
我必须编写一个将 select 语句中的结果集插入表中的过程。我的一位同事之前做过类似的事情,将值从一个表复制到另一个表。他的声明是这样的:
CREATE OR REPLACE PROCEDURE Co-Worker(
pId IN INT
)
AS
BEGIN
INSERT INTO Table1_PROCESSED
SELECT * FROM Table1
WHERE ID = pId;
DELETE FROM Table1
WHERE ID = pId;
END Co-Worker;
/
这里提到的两个表具有相同的结构(实际上 table1_processed 只是表 1 的副本)。所以我想“嘿!我也从我的选择语句中得到了一个结果集!所以我为什么不稍微调整一下呢!” 所以我像这样创建了我的表:
MyTable:
TIMEID (number) | NAME (varchar2 - 128)
-----------------------------------
VALUE | VALUE
VALUE | VALUE
VALUE | VALUE
我的程序是这样的:
CREATE OR REPLACE procedure MyProcedure(
pdate in date,
pJobtype in number default 3,
pTasktype in number default 4,
pJobstatus in number default 1,
pTaskstatus in number default 4
)
AS
pformateddate date;
BEGIN
Select to_date(to_char(to_date(pdate, 'DD.MM.YYYY HH24:MI:SS'), 'DD.MM.YYYY'), 'DD.MM.YYYY')
into pformateddate
from dual;
Insert into MyTable (TIMEID, NAME)
Select Function_GETTIMEID(to_date(st, 'DD.MM.YYYY HH24')) TIMEID
,to_char(ext) NAME
from(
Select to_char(arch_job.exec_start, 'DD.MM.YYYY HH24') st
,file.name ext
, count(file.id) cnt
from
arch_task_file
left join file on arch_task_file.File_ID = file.ID
left join arch_task on arch_task_file.Task_ID = arch_task.ID
left join arch_job on arch_task.Job_ID = arch_job.ID
where
arch_job.exec_start > pformateddate
and arch_job.exec_end <pformateddate + 1
and arch_job.jobtype_id = pJobtype
and arch_job.jobstatus_id = pJobstatus
and arch_task.Tasktype_ID = pTasktype
and arch_task.Taskstatus_ID = pTaskstatus
group by
file.name,
to_char(arch_job.exec_start, 'DD.MM.YYYY HH24'
)
);
End MyProcedure;
/
大型 Select-Statement ALONE 的结果如下所示:
TIMEID | NAME
-----------------------------------
VALUE | VALUE
VALUE | VALUE
VALUE | VALUE
但是,如果我执行此过程并给它一个 dummydate(sysdate - 12 或类似 '16.07.2010 10:32:50' 的日期),我的 Toad 会给我一条消息“过程已完成”,我的表仍然是空的......!但正如之前所说,大的 Select-Statement 给出了结果,所以不应该尝试插入一个空的结果集......!谁能告诉我为什么我的程序不起作用?
感谢每个有用的答案。=)
问候!
PS:该
Select to_date(to_char(to_date(pdate, 'DD.MM.YYYY HH24:MI:SS'), 'DD.MM.YYYY'), 'DD.MM.YYYY')
into pformateddate
from dual;
需要缩短 pDate 值!我测试了它,所以它也可以工作,你可以在整个逻辑中忽略它。它只是在这里给你一个完整的情况!