oracle字段能大小写混写吗
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle字段能大小写混写吗相关的知识,希望对你有一定的参考价值。
oracle字段名是不区分大小写的,所以可以大小写混写。
如,字段名小写,可查出如下结果:
字段名大写,结果不变:
字段名大小写混合,结果不变:
参考技术A Oracle的所有命令、语句、对象名及各种名称对大小不敏感。只有对具体数据是敏感的。所以在条件查询进行字符比较时,一定要区分大小写。直观地说单引号里的内容是分大小写的。本回答被提问者和网友采纳 参考技术B 哦,oracle数据库的系统表名及字段名都是大写的。建议不要混用。大小一致比较好。 参考技术C 有些特殊情况是不能混写的,例如,我在建表的时候写成这样:create table "Test" (a char(1));
那么在查询的时候你只能:
select * from "Test";
而不能写成
select * from test; 参考技术D 可以,但是oracle实际都转换成大写的了
oracle中,改变表名和字段名的大小写
1.将表名和字段名改为大写 见-- http://www.cnblogs.com/wenboge/articles/4121331.html
2.将表名和字段名改为小写
①改表名为小写
begin for c in (select table_name tn from user_tables where table_name <> lower(table_name)) loop begin execute immediate \'alter table \'||c.tn||\' rename to "\'||lower(c.tn)||\'"\'; exception when others then dbms_output.put_line(c.tn||\'已存在\'); end; end loop; end;
②改字段名为小写
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 "\'||lower(c.cn)||\'"\'; exception when others then dbms_output.put_line(t.tn||\'.\'||c.cn||\'已经存在\'); end; end loop; end; end loop; end;
注:
1.如果字段和表名都要改为小写,先改字段,再改表。
2.如果表名获取字段名改为小写以后,要在查询语句中将表名和字段名都要加上双引号
例.
表名小写 :select * from "department";
字段名小写:select "id" from "department";
我也不知道为啥这样
以上是关于oracle字段能大小写混写吗的主要内容,如果未能解决你的问题,请参考以下文章