Oracle跨ower操作

本文介绍了一个 Oracle PL/SQL 过程,用于从一个表 (Table1) 中检索所有 NUMBER 类型的列,并将这些列的 NULL 值设置为 0 在另一个表 (Table2) 中。此过程通过遍历第一个表的所有符合条件的列并更新第二个表来实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

create or replace procedure SP_ChangeOneTabToAnother is
 strSql     varchar2(200);
begin
dbms_output.put_line('begin');
for c_colName in ( select t.column_name
                 from ALL_TAB_COLUMNS t
                 where t.table_name='Table1'
                 and t.data_type like 'NUMBER%'
                  and t.owner = 'Owner1')
loop
  dbms_output.put_line(c_colName.Column_Name);
  strSql:='update owner2.table2 set ' || c_colName.Column_Name||' =0 where '||  c_colName.Column_Name|| ' is null'; 
  dbms_output.put_line(strSql);
  execute immediate strSql;
  commit;
end loop;
end SP_FACARD_NUMMOD;
/
exec SP_FACARD_NUMMOD;  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值