oracle动态SQL

1 篇文章 0 订阅
1 篇文章 0 订阅

create or replace procedure proc_rgb_optimation_backup (p_table_name varchar2) is
sql_statement varchar2(500);
i_l_count pls_integer;
sql_count varchar2(200);
new_table varchar2(30);
begin
  new_table := 'TBL_BMCODE_RGB_OPT_' || to_char(sysdate,'yyyyMMdd'); --变量赋值用 :=
  i_l_count := 0;
  sql_count := 'select count(*) from user_tables t where t.TABLE_NAME =' 
   || '''' || new_table || '''';  --这里注意 两个单引号表示一个单引号(‘)
  execute immediate sql_count into i_l_count;  -- 用 execute immediate 来执行sql . 用 into 来接收返回值
  if i_l_count<=0 then
  sql_statement := 'create table ' || new_table || ' as select * From ' || p_table_name;
  else
    sql_statement := 'INSERT INTO ' || new_table || '(BM_CODE,SPEED,RGB_OLD,RGB_OPTI,TRAVELTIME,TIMESTAMP,DURATION,SAMPLE,NUM_RED,NUM_YELLOW) select BM_CODE,SPEED,RGB_OLD,RGB_OPTI,TRAVELTIME,TIMESTAMP,DURATION,SAMPLE,NUM_RED,NUM_YELLOW from ' || p_table_name;
  end if;
  execute immediate sql_statement;
  commit;
  
  EXCEPTION  
    WHEN dup_val_on_index THEN     
      rollback;
    WHEN timeout_on_resource THEN
      rollback;
    WHEN NO_DATA_FOUND THEN     
      rollback;
end;

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值