调用DB2分表存储过程

CREATE PROCEDURE “DB2”.”FENBIAO” ()
language sql
begin
declare v_xbm varchar(50);
declare v_jbm varchar(50);
declare v_a1 integer default 0;
declare v_b1 integer default 0;
declare v_bmhz varchar(20) default ‘2016’;
declare v_sql varchar(1000);

declare exit handler for sqlexception
begin
rollback ;
end;

a1:begin
declare s_cur cursor with hold for
select
a. tabname
from
syscat.tables a,syscat.columns b where
a.tabname = b.tabname
and b.colname = ‘BATCHDATE’
and type = ‘T’
and card > ‘1000000’;

declare continue handler for not found set v_a1 = 1;

declare global temporary table session.tmp(
    name varchar(50)
) on commit preserve rows with replace not logged;

open s_cur;
fetch_loop1:loop
  fetch s_cur into v_jbm;
  if v_a1 = 0 then
    set v_sql = 'insert into session.tmp select '''||v_jbm||''' from '||v_jbm||' where substr(trim(batchdate),1,4) = '||v_bmhz||' having count(*) > 1000';
    prepare cre from v_sql;
    execute cre;
    commit;
    set v_a1 = 0;
  else
    leave fetch_loop1;
  end if ;
end loop fetch_loop1;
close s_cur;
commit;

b1:begin
  declare c_cur cursor with hold for select name from session.tmp ;
  declare continue handler for not found set v_b1 = 1;
  open c_cur;
  fetch_loop2:loop
    fetch c_cur into v_jbm;
    if v_b1 = 0 then
      set v_xbm = v_jbm||'_'||v_bmhz;
      set v_sql = 'create table '||v_xbm||' as (select * from '||v_jbm||') definition only';
      prepare cre from v_sql;
      execute cre;
      set v_sql = 'insert into '||v_xbm||' select * from '||v_jbm||' where substr(trim(batchdate),1,4) = '||v_bmhz;
      prepare cre from v_sql;
      execute cre;
      set v_sql = 'delete from '||v_jbm||' where substr(trim(batchdate),1,4) = '||v_bmhz;
      prepare cre from v_sql;
      execute cre;
      commit;
              else
      leave fetch_loop2;
    end if ;
  end loop fetch_loop2;
  close c_cur;
end b1;

end a1;

end
@

–调用存储过程
db2 -tvf 1.sql -td@

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值