想要把原sql语句写成存储过程,这样以后就直接调用存储过程来执行这一段语句了
求大神帮忙看看我写的是否正确,谢谢
原sql语句:
TRUNCATE TABLE tab1;
INSERT tab1
SELECT s.storecode,s.category,nvl(curr.vol,0)/s.avg_vol - 1 AS growth
FROM
(
SELECT periodcode,storecode,CATEGORY,vol FROM tab2 WHERE periodcode = &periodcode) curr,
(SELECT storecode,category,AVG(vol) avg_vol FROM tab2
GROUP BY storecode,CATEGORY HAVING AVG(vol) > 0) s
WHERE curr.storecode(+) = aveg.storecode
AND curr.category(+) = s.category
打包为存储过程:
create or replace procedure p_tab1
AS
BEGIN
TRUNCATE TABLE tab1;
INSERT tab1
SELECT s.storecode,s.category,nvl(curr.vol,0)/s.avg_vol - 1 AS growth
FROM
(
SELECT periodcode,storecode,CATEGORY,vol FROM tab2 WHERE periodcode = &periodcode) curr,
(SELECT storecode,category,AVG(vol) avg_vol FROM tab2
GROUP BY storecode,CATEGORY HAVING AVG(vol) > 0) s
WHERE curr.storecode(+) = aveg.storecode
AND curr.category(+) = s.category
COMMIT;
END;