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

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
将原来的数据更新到新字段中这是要注意一定要显示进行数据类型转换sqlstr
Oracle批量更改所有表的字段取值 _类型 _原字段名
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 mp_column'; dbms_output.put_line('sql_str: '||sql_str); execute immediate sql_str; commit; end loop; close c_tab; end;
相关文档
最新文档