存储过程游标的使用

全过程带注释

CREATE OR REPLACE PROCEDURE "基站通报11111111_LI"(v_period IN VARCHAR2) AS
		unitname1b VARCHAR2(20);
		unitname2b VARCHAR2(20);
		unitname3b VARCHAR2(20);
		unitname4b VARCHAR2(20);
		unitname5b VARCHAR2(20);
		unitname6b VARCHAR2(20);
    numberu1b NUMBER;
    numberu2b NUMBER;
    numberu3b NUMBER;
    numberu4b NUMBER;
    numberu5b NUMBER;
    numberu6b NUMBER;	
		    TYPE cur_type IS RECORD (
        c_unitname jilin.dt_site_profit_unit.c_unitname%TYPE,  -- 地市名称
        Ratio      NUMBER,                                      -- 比率
        RankHigh   NUMBER                                       -- 排名
    );
		-- 声明一个变量来存储从游标提取的数据
    cur_rec cur_type;
    -- 小于0大于-5000
    counterb NUMBER := 0; 
    CURSOR curb IS
        SELECT *
        FROM (
            SELECT 
                a.c_unitname,
                ROUND(100 * n_amount2 / n_amount5, 2) AS Ratio,
                RANK() OVER (ORDER BY n_amount2 / n_amount5 DESC) AS RankHigh 
            FROM
                jilin.dt_site_profit_unit a
                LEFT JOIN jilin.base_unit_order b ON a.c_unitno = b.c_unitno
            WHERE
                c_period = v_period AND 
                a.c_unitname != '全省'
        ) t
        WHERE
            RankHigh IN (1, 2, 3, 7, 8, 9)
        ORDER BY
            RankHigh;
  
BEGIN
  
  -- 打开游标
    OPEN curb;
    
    -- 循环提取数据
    LOOP
        -- 提取一行数据到 cur_rec 中
        FETCH curb INTO cur_rec;
        
        -- 检查是否已提取完所有数据
        EXIT WHEN curb%NOTFOUND;
				
				
        -- 增加计数器
        counterb := counterb + 1;
        
        -- 根据计数器值将 c_unitname 赋予不同的变量
        CASE counterb
            WHEN 1 THEN unitname1b := cur_rec.c_unitname;
												numberu1b := cur_rec.Ratio;
            WHEN 2 THEN unitname2b := cur_rec.c_unitname;
												numberu2b := cur_rec.Ratio;
            WHEN 3 THEN unitname3b := cur_rec.c_unitname;
												numberu3b := cur_rec.Ratio;
            WHEN 4 THEN unitname4b := cur_rec.c_unitname;
												numberu4b := cur_rec.Ratio;
            WHEN 5 THEN unitname5b := cur_rec.c_unitname;
												numberu5b := cur_rec.Ratio;
            WHEN 6 THEN unitname6b := cur_rec.c_unitname;
												numberu6b := cur_rec.Ratio;
        END CASE;
    END LOOP;
    
    -- 关闭游标
    CLOSE curb;
 
 
  -- 删除指定期间的记录
  DELETE FROM JILIN.WORD_ICT_DETAILS WHERE c_period = v_period AND C_TYPE='基站';
  COMMIT; -- 提交删除操作
  -- 插入值
  INSERT INTO JILIN.WORD_ICT_DETAILS
  VALUES (v_period,unitname1b,'基站');
  COMMIT; -- 提交插入操作
  
EXCEPTION
  WHEN OTHERS THEN
    DBMS_OUTPUT.PUT_LINE('发生错误: ' || SQLCODE || ' - ' || SQLERRM);
    ROLLBACK; -- 回滚事务,撤销所有对数据库的更改
END;

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 存储过程中可以使用游标来处理结果集。游标是一种指向结果集的命名数据结构,可以通过游标来访问结果集中的数据行。下面是一个简单的示例,演示了如何在 Oracle 存储过程使用游标。 ```sql CREATE OR REPLACE PROCEDURE my_proc IS -- 声明游标类型 CURSOR my_cursor IS SELECT column1, column2, column3 FROM my_table WHERE column4 = 'some condition'; -- 声明游标返回的数据类型 TYPE my_cursor_type IS RECORD ( column1 my_table.column1%TYPE, column2 my_table.column2%TYPE, column3 my_table.column3%TYPE ); -- 声明变量来存储游标返回的数据 my_data my_cursor_type; BEGIN -- 打开游标 OPEN my_cursor; -- 循环遍历游标返回的结果集 LOOP -- 获取下一行数据 FETCH my_cursor INTO my_data; -- 判断是否还有数据 EXIT WHEN my_cursor%NOTFOUND; -- 处理游标返回的数据 -- ... END LOOP; -- 关闭游标 CLOSE my_cursor; END; ``` 在这个示例中,我们首先声明了一个游标类型 `my_cursor`,并且定义了游标返回的数据类型 `my_cursor_type`。然后我们声明了一个变量 `my_data`,用来存储游标返回的数据。 在存储过程主体中,我们首先打开游标 `my_cursor`,然后使用 `LOOP` 循环遍历游标返回的结果集。在循环体中,我们使用 `FETCH` 语句获取下一行数据,并且判断是否还有数据。如果没有数据了,我们使用 `EXIT` 语句退出循环。否则,我们可以处理游标返回的数据,比如将其插入到另外一个表中。最后,我们关闭游标 `my_cursor`,释放资源。 需要注意的是,在存储过程使用游标可能会影响性能,特别是当处理大量数据时。因此,我们应该尽可能地使用 SQL 查询语句来处理结果集,而不是使用游标
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值