oracle批量改所有表数据类型,【oracle】批量更改所有表的同一字段类型

【oracle】批量更改所有表的同一字段类型。经常需要oracle中的所有的字段的类型更改为另外一个类型,可以考虑利用如下代码:此处的demo为将NVARCHAR2转为VARCHAR2类型并且字段长度保持不变。

declare

cursor c_tab is select * from user_tab_columns t where t.data_type = 'NVARCHAR2';

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值