1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

请注意Oracle对象的大小写

2022-11-18 | 数据库 | admin | 503°c
A+ A-

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

CREATETABLEtest 
( 
idNUMBER(10), 
NameVARCHAR2(20), 
SexVARCHAR(2) 
) 
--查找不到对应数据 
SELECT*FROMUSER_TABLESWHERETABLE_NAME='test'
--改用大写才可以查到对应的数据 
SELECT*FROMUSER_TABLESWHERETABLE_NAME='TEST'
--查找不到对应数据 
SELECT*FROMALL_TAB_COLUMNSWHERETABLE_NAME='test'; 
SELECT*FROMUSER_TAB_COLUMNSWHERETABLE_NAME='TEST';

下面我们用双引号来新建另外一个表(ORACLE 中" "的作用是强制区分大小写,以及关键字做字段时用"")脚本如下所示:

CREATETABLE"test1"
( 
"id"NUMBER(10), 
"Name"VARCHAR2(20), 
"SEX"VARCHAR(2) 
) 
SELECT*FROMUSER_TABLESWHERETABLE_NAME='test1'; 
SELECT*FROMDBA_TABLESWHERETABLE_NAME='test1'; 
SELECT*FROMUSER_TAB_COLUMNSWHERETABLE_NAME='test1'; 
SELECT*FROM"test1"; 
--ORA-00942:表或试图不存在 
SELECT*FROMtest1; 
--ORA-00904:"NAME":标识符无效 
SELECTid,Name,SEXFROM"test1"; 
--ORA-00904:"ID":标识符无效 
SELECTid,"Name",SEXFROM"test1"; 
SELECT"id","Name",SEXFROM"test1"; 
--ORA-00942:表或试图不存在 
SELECT"id","Name",SEXFROMtest1; 

上面的例子也许会让觉得比较奇怪,这种现象在SQL SERVER里面是不存在的。这是因为ORACLE在建表或者字段时,如果没有双引号,ORACLE会把表名、字段名全部转化为大写字母然后写入数据字典。访问数据字典时,没有双引号ORACLE会将其转化成大写然后再去数据字段中查找。如果加上双引号则能区分大小写。不仅仅关键字不区分大小写,函数名,过程名,表名称,pl/sql块中变量名,用户名,密码等都不区分大小写。

有些人可能不习惯表名、字段全部用大写,而喜欢用小写或大小写混杂的形式,如果是这样的话,你在ORACLE中写脚本时就要注意了,没有处理好,这样会给你带来“无穷的麻烦”

如上所示,你必须在字段上加上"",否则这里报错,哪里起火。而人有时候又是很粗心、健忘的。所以在ORACLE中,还是建议全部用大写,这样可能开始会让你有些不爽,不过习惯了就好了。总比你用""给后面的开发带来很多隐患要好得多。

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

本文来源:1818IP

本文地址:https://www.1818ip.com/post/4539.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。