请注意Oracle对象的大小写

2012-11-12

    在数据库新建一个测试表(数据库版本为ORACLE 10.2.0.1.0),表名为小写的test。 脚本如下所示:
    1.CREATE TABLE test
    2.(
    3.     id      NUMBER(10),
    4.     Name    VARCHAR2(20),
    5.     Sex     VARCHAR(2)
    6.)
    7.--查找不到对应数据
    8.SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test'
    9.--改用大写才可以查到对应的数据
    10.SELECT * FROM USER_TABLES WHERE TABLE_NAME ='TEST'
    11.--查找不到对应数据
    12.SELECT * FROM ALL_TAB_COLUMNS WHERE TABLE_NAME = 'test';
    13.SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='TEST';
     
    下面我们用双引号来新建另外一个表(ORACLE 中 " "的作用是强制区分大小写,以及关键字做字段时用"")脚本如下所示:
    1.CREATE TABLE "test1"
    2.(
    3.  "id"       NUMBER(10),
    4.  "Name"     VARCHAR2(20),
    5.  "SEX"      VARCHAR(2)
    6.)
    7.SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test1';
    8.SELECT * FROM DBA_TABLES WHERE TABLE_NAME = 'test1';
    9.SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='test1';
    10.SELECT * FROM "test1";
    11.--ORA-00942: 表或试图不存在
    12.SELECT * FROM test1;
    13.--ORA-00904: "NAME": 标识符无效
    14.SELECT id, Name, SEX FROM "test1";
    15.--ORA-00904: "ID": 标识符无效
    16.SELECT id, "Name", SEX FROM "test1";
    17.SELECT "id", "Name", SEX FROM "test1";
    18.--ORA-00942: 表或试图不存在
    19.SELECT "id", "Name", SEX FROM test1;
    上面的例子也许会让觉得比较奇怪,这种现象在SQL SERVER里面是不存在的。这是因为ORACLE在建表或者字段时,如果没有双引号,ORACLE会把表名、字段名全部转化为大写字母然后写入数据字典。访问数据字典时,没有双引号ORACLE会将其转化成大写然后再去数据字段中查找。如果加上双引号则能区分大小写。不仅仅关键字不区分大小写,函数名,过程名,表名称,pl/sql块中变量名,用户名,密码等都不区分大小写。
    有些人可能不习惯表名、字段全部用大写,而喜欢用小写或大小写混杂的形式,如果是这样的话,你在ORACLE中写脚本时就要注意了,没有处理好,这样会给你带来“无穷的麻烦”
    如上所示,你必须在字段上加上"",否则这里报错,哪里起火。而人有时候又是很粗心、健忘的。所以在ORACLE中,还是建议全部用大写,这样可能开始会让你有些不爽,不过习惯了就好了。总比你用""给后面的开发带来很多隐患要好得多。
    在ORAClE中,习惯脚本、字段等用大写,有人说能提高效率,这样少了强制转换大写(如果没有双引号的话)开销,也有人说这些开销可以忽略不计,不会有啥性能方面的问题。(当然脚本全部用大写一致,可以避免同一脚本由于大小写问题多次解析,这是可以肯定的)。小弟不才,也不能确定,网上这方面的资料也少,希望大家能讨论。

    考试大温馨提示:本内容来源于网络,仅代表作者个人观点,与本站立场无关,仅供您学习交流使用。其中可能有部分文章经过多次转载而造成文章内容缺失、错误或文章作者不详等问题,请您谅解。如有侵犯您的权利,请联系我们,本站会立即予以处理。

    相关推荐

    oracle中的rownum总结

    oracle维护常用语句

    数据库系统实现:数据库实现概论

分享到:
0
相关阅读
友情链接
© 2018 我考网 http://www.woexam.com 中国互联网举报中心 湘ICP备18023104号 京公网安备 11010802020116号
违法和不良信息举报:9447029@qq.com