请注意Oracle对象的大小写_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
2
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1596 | 回复: 1   主题: 请注意Oracle对象的大小写        下一篇 
lxk
注册用户
等级:上尉
经验:547
发帖:109
精华:0
注册:2011-8-18
状态:离线
发送短消息息给lxk 加好友    发送短消息息给lxk 发消息
发表于: IP:您无权察看 2015-4-22 16:05:14 | [全部帖] [楼主帖] 楼主

在数据库新建一个测试表(数据库版本为ORACLE 10.2.0.1.0),表名为小写的test脚本如下所示:

  1. CREATETABLE 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. CREATETABLE"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中,习惯脚本、字段等用大写,有人说能提高效率,这样少了强制转换大写(如果没有双引号的话)开销,也有人说这些开销可以忽略不计,不会有啥性能方面的问题。(当然脚本全部用大写一致,可以避免同一脚本由于大小写问题多次解析,这是可以肯定的)。

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
lei.wang
注册用户
等级:上尉
经验:767
发帖:21
精华:0
注册:1970-1-1
状态:离线
发送短消息息给lei.wang 加好友    发送短消息息给lei.wang 发消息
发表于: IP:您无权察看 2015-4-23 9:23:35 | [全部帖] [楼主帖] 2  楼

另外可以通过 lower或upper函数变通解决这个问题,不过大小写转换会需要额外的开销,例如:



将语句

SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test'


改造成

SELECT * FROM USER_TABLES WHERE LOWER(TABLE_NAME) = 'test'



赞(0)    操作        顶端 
总帖数
2
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论