存储过程 循环

CREATE OR REPLACE PROCEDURE test_loop as

CURSOR emp_cur IS
SELECT name,name1,weights,score FROM FACTOR where score is not null order by name;
  --声明变量接收游标中的数据
  v_name  FACTOR.name%TYPE;
  v_name1  FACTOR.name1%TYPE;
  v_weights  FACTOR.weights%TYPE;
  v_score  FACTOR.score%TYPE;
  sql2 varchar2(2000);
  v_name_const  varchar2(200):= '10000';
BEGIN
OPEN emp_cur;

  LOOP
   --获取游标中的数据   如果有的话赋值给变量
    FETCH emp_cur INTO v_name,v_name1,v_weights,v_score;
    IF v_name_const<>v_name and v_name_const<> '10000' THEN  sql2:=sql2|| 'ELSE 0.5 END),'||CHR(10);END IF;
    IF v_name_const<>v_name THEN  v_name_const:=v_name; sql2:=sql2|| 'CASE T.'||v_name||CHR(10);END IF;
    sql2:= sql2||'WHEN'||v_name1||'THEN'||CHR(10)||v_weights * v_score||CHR(10);
    EXIT WHEN emp_cur%NOTFOUND;  
  END LOOP;
  sql2:=sql2|| 'ELSE 0.5 END),';
  dbms_output.put_line(sql2);
CLOSE emp_cur;
END test_loop;'

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值