sinat_36169916 2016-09-18 09:33 采纳率: 0%
浏览 1520

oracle将sql语句写成存储过程

想要把原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;

  • 写回答

2条回答

  • AlbertS 博客专家认证 2016-09-18 09:35
    关注

    不太明白你的问题,你是要实现什么功能

    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料