oracle 创建存储过程

 创建存储过程:


CREATE OR REPLACE PROCEDURE 存储过程名称 AS
BEGIN
    需要执行的sql;
END;

创建带参数的存储过程:

CREATE OR REPLACE PROCEDURE sp_budget_share_build (
    in_ysny VARCHAR DEFAULT NULL,
    in_gs   VARCHAR  DEFAULT NULL,
    code    OUT NUMBER,
    msg     OUT VARCHAR) AS 
    YSNYVAR VARCHAR(10);
    params2 VARCHAR(20);
BEGIN
    YSNYVAR := nvl(in_ysny, to_char(sysdate, 'yyyy-mm'));
    UPDATE FLYCO_SALES_RESULTS a SET YSJE = (
    
        SELECT INPUT_YSJE FROM flyco_amortization_input b WHERE b.BMID = a.BMID AND b.YSNY = a.YSNY AND a.YSZBXH = b.INPUT_YSZBXH

    ) WHERE YSNY = YSNYVAR AND EXISTS(
        SELECT INPUT_YSJE FROM flyco_amortization_input b WHERE b.BMID = a.BMID AND b.YSNY = a.YSNY AND a.YSZBXH = b.INPUT_YSZBXH
    );
END;

CREATE OR REPLACE PROCEDURE  存储过程名称。     创建或替换存储过程

sp_budget_share_build                                                        存储过程名称

in_ysny 、in_gs                                                                   入参 默认值为null

msg   code。                                                                        出参(out不能丢哦)

调用存储过程:


declare
  msg           VARCHAR2(4000);
  code          NUMBER; 
BEGIN
-- 存储过程明(入参,入参,将变量传递进去 当作存储过程的out值,将变量传递进去 当作存储过程的out值)
  sp_budget_share_build('2022-05',NULL, code, msg);
   dbms_output.put_line( '--' || code || '---' || msg); 
end;

查看存储过程(TEST_FUNCTION为存储过程名称):

SELECT
	text 
FROM
	user_source 
WHERE
	NAME = 'TEST_FUNCTION' 
ORDER BY
	line

删除存储过程:

DROP PROCEDURE 存储过程名称

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值