ORACLE对象大小写问题
2023-09-14 08:58:20 时间
在数据库新建一个测试表(数据库版本为ORACLE 10.2.0.1.0),表名为小写的test。 脚本如下所示:
CREATE TABLE test id NUMBER(10), Name VARCHAR2(20), Sex VARCHAR(2)
下面我们用双引号来新建另外一个表(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的数据库对象了 数据库的功能就是组织管理和存储各种数据库对象。数据库中的对象是我们进行数据管理的基本。本篇会回顾一下数据库对象的一些基本知识,让我们更加清晰的了解这些Oracle数据库对象。
潇湘隐者 网名潇湘隐者/潇湘剑客、英文名Kerry,兴趣广泛,广泛涉猎,个性随意,不善言辞。执意做一名会写代码的DBA,混迹于IT行业
相关文章
- Oracle官方并发教程之不可变对象
- 忘记oracle的sys用户密码如何修改以及Oracle 11g 默认用户名和密码
- Oracle数据库使用出现错误-状态: 失败 ORA-01034: ORACLE not available ORA-27101: shared memory realm does not exist
- Oracle 11g安装步骤以及Oracle11g创建表空间和用户,并授权
- 【Oracle】oracle的LAG和LEAD分析函数
- 【Python Oracle】使用cx_Oracle 连接oracle的简单介绍
- 如何将oracle 对象pin在共享池中
- 《oracle每天一练》Merge Into 语句代替Insert/Update在Oracle中的应用实战
- ORACLE 常用函数——转换函数
- Oracle计算时间函数(对时间的加减numtodsinterval、numtoyminterval) (转)
- oracle常用函数使用大全 Oracle除法(转)
- Oracle表空间不足处理
- oracle 10g 32位 快速安装
- Oracle flashback
- oracle静态注册
- oracle 11g在安装过程中出现监听程序未启动或数据库服务未注册到该监听程序
- Oracle中添加虚拟列(emp是oracle自带表)
- 【Oracle】Oracle表空间数据文件大小设置
- Oracle EBS 入门
- Oracle 12c中SQLPlus操作使用(包含实验二ORACLE SQL*PLUS环境与查询的详细操作解释)
- Oracle的学习心得和知识总结(十三)|Oracle数据库Real Application Testing之Database Replay实操(一)
- 【Mysql异构实时同步Oracle】OGG12异构同步mysql到oracle(windows mysql实时同步数据到linux oracle)详细文档