首页 > 数据库技术 > 详细

[navicate将mysql数据库数据复制到oracle数据库]--批量将oracle 表名和字段名变为大写

时间:2020-08-21 09:29:57      阅读:92      评论:0      收藏:0      [点我收藏+]
当使用powerdesigner创建数据库时要注意大小写。
注:以下脚本在oracle 10g,11g上正确执行
 
1.批量将表名变为大写

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 ‘||c.tn;
exception
when others then
dbms_output.put_line(c.tn||‘已存在‘);
end;
end loop;
end;

 

2.批量将空间内所有表的所有字段名变成大写

begin
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 ‘||c.cn;
exception
when others then
dbms_output.put_line(t.tn||‘.‘||c.cn||‘已经存在‘);
end;
end loop;
end;
end loop;
end;

 
3.将用户空间的所有表名及所有字段变为大写

begin
for t in (select table_name tn from user_tables where table_name <> upper(table_name)) 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 ‘||c.cn;
exception
when others then
dbms_output.put_line(t.tn||‘.‘||c.cn||‘已经存在‘);
end;
end loop;

execute immediate ‘alter table "‘||t.tn||‘" rename to ‘||t.tn;
exception
when others then
dbms_output.put_line(t.tn||‘已存在‘);
end;
end loop;
end;

[navicate将mysql数据库数据复制到oracle数据库]--批量将oracle 表名和字段名变为大写

原文:https://www.cnblogs.com/curedfisher/p/13539129.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!