ORACLE 所有表的所有字段去空格方法

最近的项目是从informix库抽数据到oracle库,

没想到抽过来的数据,几乎都有空格把varchar2类型的字段填满了,导致条件查询失败

特写了个所有表去空格的方法,有需要的可以直接拿去用

 

create or replace procedure trimtab is
  --所有表 去空格

  /*1、查询出所有表存放在一个集合里
  2、循环每个表,处理
        --获取表的字段名
        select A.COLUMN_NAME,A.DATA_TYPE  from user_tab_columns A
        where TABLE_NAME=upper('action_forcheck')
  */
    v_sql        varchar2(2000);
    v_table_name varchar2(30);
    cursor tables is
      select table_name from user_tables
        where table_name not like 'JBPM4%';

    TYPE FILED_LISTS IS REF CURSOR; --字段名集合
    v_listf FILED_LISTS;
    V_FILED      varchar2(30);
  begin
    open tables;
    loop
      --提取一行数据到 tables
      fetch tables
        into v_table_name;
      --判读是否提取到值,没取到值就退出
      exit when tables%notfound;

      OPEN v_listf FOR
            select A.COLUMN_NAME from user_tab_columns A
            where TABLE_NAME=upper(v_table_name);
        LOOP
            FETCH v_listf
                INTO V_FILED;
            EXIT WHEN v_listf%NOTFOUND;

            v_sql :=  'UPDATE '||v_table_name|| ' SET  '|| V_FILED ||'=TRIM('||V_FILED||')'    ;
            execute immediate v_sql;
            COMMIT;
        END LOOP;
        CLOSE v_listf;

    end loop; --关闭游标
    close tables;
  end;

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值