加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle批量更改所有表的字段取值_类型_原字段名

发布时间:2020-12-12 12:59:55 所属栏目:百科 来源:网络整理
导读:CREATE PROCEDURE 存储过程名称 is cursor c_tab is select * from user_tab_columns t r_tab user_tab_columns % rowtype; v_cell varchar2 ( 100 ); sql_str varchar2 ( 1000 ); data_length number ; begin open c_tab; loop fetch c_tab into r_tab; exi
CREATE PROCEDURE 存储过程名称
is
cursor c_tab is select * from user_tab_columns t 
  r_tab user_tab_columns%rowtype;
  v_cell varchar2(100);
  sql_str varchar2(1000);
  data_length number;
begin
  open c_tab;
  loop
    fetch c_tab into r_tab;
    exit when c_tab%notfound;
    v_cell:=‘‘;
    data_length:=trunc(r_tab.data_length/2,0);
    sql_str:=select max(||r_tab.column_name||) from ||r_tab.table_name;
    dbms_output.put_line(sql_str: ||sql_str);
    execute immediate sql_str into v_cell;
    commit;
    dbms_output.put_line(value: ||v_cell);
    dbms_output.put_line(table name: ||r_tab.table_name|| column name: ||r_tab.column_name|| length: ||r_tab.data_length);
    --1. 修改原字段名  
    sql_str:=alter table ||r_tab.table_name|| rename column ||r_tab.column_name|| to temp_column;
    dbms_output.put_line(sql_str: ||sql_str);
    execute immediate sql_str;
    commit;
    --2. 添加一个和原字段同名的字段
    sql_str:=ALTER TABLE ||r_tab.table_name|| ADD ||r_tab.column_name|| VARCHAR2(||data_length||);
    dbms_output.put_line(sql_str: ||sql_str);
    execute immediate sql_str;
    commit;
    --3. 将原来的数据更新到新字段中,这是要注意,一定要显示进行数据类型转换
    sql_str:=UPDATE ||r_tab.table_name|| SET ||r_tab.column_name|| = CAST(temp_column AS VARCHAR2(||data_length||));
    dbms_output.put_line(sql_str: ||sql_str);
    execute immediate sql_str;
    commit;
    --4. 删除原来的备份字段
    sql_str:=ALTER TABLE ||r_tab.table_name|| DROP COLUMN temp_column;
    dbms_output.put_line(sql_str: ||sql_str);
    execute immediate sql_str;
    commit;
  end loop;
  close c_tab;
end;

注:根据自己需求适当调整即可。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读