-- 修改数据库表名大小写
begin
-- 遍历所有的表名
for c in (select table_name tn from user_tables where table_name <> upper(table_name) ) loop
begin
-- 执行修改
execute immediate 'alter table "'c.tn'" rename to "'upper(c.tn)'"';
exception
when others then
-- 已经存在,输出提示
dbms_output.put_line(c.tn'已存在');
end;
end loop;
end;
begin
-- 启动缓冲
DBMS_OUTPUT.ENABLE (buffer_size=>null) ;
-- 遍历所有表名
for t in (select table_name tn from user_tables) loop
begin
-- 遍历所有列名
for c in (select column_name cn from user_tab_columns where table_name=t.tn) loop
begin
--执行修改语句 注意双引号 与拼接 外单内双
execute immediate 'alter table "'t.tn'" rename column "'c.cn'" to "'upper(c.cn)'"';
-- 异常处理
exception
when others then
dbms_output.put_line(t.tn'.'c.cn'已经存在');
end;
end loop;
end;
end loop;
end;
共同学习,写下你的评论
评论加载中...
作者其他优质文章