当前位置:Gxlcms > 数据库问题 > Oracle数据库存储过程练习20181212

Oracle数据库存储过程练习20181212

时间:2021-07-01 10:21:17 帮助过:3人阅读

测试表 CREATE TABLE TEST20181207 ( ID INTEGER PRIMARY KEY, FUND NUMBER,--上日资金 BALANCE NUMBER,--本日资金 CDATE VARCHAR2(10) );

添加测试数据:

--添加测试数据
INSERT INTO TEST20181207 VALUES(1,100,200,2018-10-31);
INSERT INTO TEST20181207 VALUES(2,100,200,2018-11-01);
INSERT INTO TEST20181207 VALUES(3,200,0,2018-11-03);
INSERT INTO TEST20181207 VALUES(4,0,100,2018-11-10);
INSERT INTO TEST20181207 VALUES(5,100,0,2018-11-20);
INSERT INTO TEST20181207 VALUES(6,10,100,2018-11-10);
INSERT INTO TEST20181207 VALUES(7,100,0,2018-11-20);
COMMIT;

创建存储过程:

CREATE OR REPLACE PROCEDURE TESTSELECT20181207
(I_START_DATE VARCHAR2,
I_END_DATE VARCHAR2)
IS
  T_ID1 INTEGER;
  T_FUND1 NUMBER;
  T_BALANCE1 NUMBER;
  T_CDATE1 VARCHAR2(10);
  T_ID2 INTEGER;
  T_FUND2 NUMBER;
  T_BALANCE2 NUMBER;
  T_CDATE2 VARCHAR2(10);
  CURSOR CURSOR1 IS
  SELECT ID,FUND,BALANCE,CDATE FROM TEST20181207
  WHERE CDATE BETWEEN I_START_DATE AND I_END_DATE;
  CURSOR CURSOR2(T_CDATE VARCHAR2) IS
  SELECT ID,FUND,BALANCE,CDATE FROM TEST20181207
  WHERE CDATE = (
    SELECT MIN(CDATE) FROM TEST20181207
    WHERE CDATE > T_CDATE
  )
  AND CDATE BETWEEN I_START_DATE AND I_END_DATE;
BEGIN
  OPEN CURSOR1;
  LOOP
    FETCH CURSOR1 INTO T_ID1,T_FUND1,T_BALANCE1,T_CDATE1;
    EXIT WHEN CURSOR1%NOTFOUND;
    OPEN CURSOR2(T_CDATE1);
      LOOP
        FETCH CURSOR2 INTO T_ID2,T_FUND2,T_BALANCE2,T_CDATE2;        
        EXIT WHEN CURSOR2%NOTFOUND;
        IF T_FUND2 <> T_BALANCE1 THEN
          DBMS_OUTPUT.PUT_LINE(编号1:||T_ID1||,本日资金1:||T_BALANCE1||,日期1:||T_CDATE1);
          DBMS_OUTPUT.PUT_LINE(编号2:||T_ID2||,上日资金2:||T_FUND2||,日期2:||T_CDATE2);
        END IF;
      END LOOP;
    CLOSE CURSOR2; 
  END LOOP;
  CLOSE CURSOR1;
END TESTSELECT20181207;
/

最后一个/在同时执行创建多个存储过程是必须的,/代表一个存储过程代码的结尾(结束).

调用存储过程:

CALL TESTSELECT20181207(2018-10-31,2018-11-30);

运行结果:

技术分享图片

好了,就这样了.

Oracle数据库存储过程练习20181212

标签:存储   执行   open   exit   where   end   oracl   .com   not   

人气教程排行