Oracle批量变动全部表的字段取值_范例_原字段名
发布时间:2021-03-22 12:44:20 所属栏目:站长百科 来源:网络整理
导读: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; 注:按照本身需求恰当调解即可。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |