请注意Oracle对象的大小写
创始人
2024-07-28 10:00:34
0

在数据库新建一个测试表(数据库版本为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中,习惯脚本、字段等用大写,有人说能提高效率,这样少了强制转换大写(如果没有双引号的话)开销,也有人说这些开销可以忽略不计,不会有啥性能方面的问题。(当然脚本全部用大写一致,可以避免同一脚本由于大小写问题多次解析,这是可以肯定的)。小弟不才,也不能确定,网上这方面的资料也少,希望大家能讨论 

原文链接:http://www.cnblogs.com/kerrycode/archive/2011/05/05/2037151.html

【编辑推荐】

  1. Oracle的安全标记算不算bug
  2. 浅述当前模式读与一致性读续
  3. 浅述当前模式读与一致性读的区别
  4. 告诉你,如何成就DBA职业生涯
  5. Oracle业务就绪存储系统助力企业实现存储升级

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...