ORACLE对象大小写问题

摘要:
在数据库中创建新的测试表。表名为小写测试。这是因为当ORACLE构建表或字段时,如果没有双引号,ORACLE会将表名和字段名转换为大写字母,并将它们写入数据字典。因此,在ORACLE中,建议使用所有大写字母,这可能最初会让您感到不舒服,但习惯它是很好的。

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

CREATE TABLE test
(
     id      
NUMBER(10),
     Name    
VARCHAR2(20),
     Sex     
VARCHAR(2)
)


--查找不到对应数据
SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test'

--改用大写才可以查到对应的数据
SELECT * FROM USER_TABLES WHERE TABLE_NAME ='TEST'

--查找不到对应数据
SELECT * FROM ALL_TAB_COLUMNS WHERE TABLE_NAME = 'test';

SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='TEST'; 

ORACLE对象大小写问题第1张

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

CREATE TABLE "test1"

  "id"       
NUMBER(10),
  "Name"     
VARCHAR2(20),
  "SEX"      
VARCHAR(2)
)
 
SELECT * FROM USER_TABLES WHERE TABLE_NAME = 'test1';

SELECT * FROM DBA_TABLES WHERE TABLE_NAME = 'test1';

SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME ='test1';

SELECT * FROM "test1";

--ORA-00942: 表或试图不存在
SELECT * FROM test1;

--ORA-00904: "NAME": 标识符无效
SELECT id, Name, SEX FROM "test1";

--ORA-00904: "ID": 标识符无效
SELECT id, "Name", SEX FROM "test1";

SELECT "id", "Name", SEX FROM "test1";

--ORA-00942: 表或试图不存在

SELECT "id", "Name", SEX FROM test1;  

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

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

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

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

免责声明:文章转载自《ORACLE对象大小写问题》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Python Web自动化测试Spring整合Redis下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Oracle中trace的几种(Z)

我们在Oracle中在做troubleshooting的时候,经常要去做跟踪来查错,那今天就介绍几种trace的方法。 在这之前,我先说说10046事件,那么大家可能都对这个事件比较熟悉了,实际上,我们做SQL TRACE的时候,Oracle内部就是使用这个事件来完成的,他包含几个级别的。如下表(trouble shooting Oracle Perfor...

mybatis以及预编译如何防止SQL注入

SQL注入是一种代码注入技术,用于攻击数据驱动的应用,恶意的SQL语句被插入到执行的实体字段中(例如,为了转储数据库内容给攻击者)。[摘自]SQL injection - Wikipedia SQL注入,大家都不陌生,是一种常见的攻击方式。攻击者在界面的表单信息或URL上输入一些奇怪的SQL片段(例如“or ‘1’=’1’”这样的语句),有可能入侵参数检验...

下拉框处理(select)

转:http://www.imdsx.cn/index.php/2017/12/04/select/ 在UI自动化测试过程中,经常会遇到一些下拉框,我们有三种可选方式来操作下拉框。 第一种方法 基于webdriver的两次click,很容易出现问题,不建议使用。(由于部分下拉框在点击一次后,失去焦点再点下一次时可能下拉框中的参数就消失了,那么就无法进行选择...

Oracle多用户对一个表进行并发插入数据行操作

    oracle数据库支持多用户间同时对同一个表进行操作,但是数据不一定同步,因为oracle数据库是支持脏数据的,比如A用户删除了表的数据但没有提交,B用户也能查询访问到,如果要避免这种情况只能加锁,A用户在操作表时先进行select * from table_name for update,这是,如果B用户再查询时只会等待A用户提交完成后才能查询到...

日记账导入API

PROCEDURE IMPORT_GL_INTERFACE IS CURSOR CUR_GL_TEMP IS SELECT GL.REFERENCE1, --批名 GL.REFERENCE2, --批说明 GL.GL_NAME, --日记账 GL.DESCRIPTION, --日记账说明 GL.SET_BOOK_NAME, --分类账套 GL.PERIO...

xcode查版本xcodebuild -version

终端输入 xcodebuild -version 如果报错: xcode-select: error: tool 'xcodebuild' requires Xcode, but active developer directory '/Library/Developer/CommandLineTools' is a command line tools...