在数据库新建一个测试表(数据库版本为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 中 " "的作用是强制区分大小写,以及关键字做字段时用"")脚本如下所示:

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

最新文章

  1. 探究@property申明对象属性时copy与strong的区别
  2. AI人工智能系列随笔
  3. 关于 MySQL UTF8 编码下生僻字符插入失败/假死问题的分析
  4. poj 2063 Investment
  5. Java_Spring MVC_Servlet
  6. 第九篇、微信小程序-button组件
  7. clrscr( )用法
  8. 【javascript 动态添加数据到 HTML 页面】
  9. arp欺骗
  10. 对话框 自定义 IOS风格 包青天
  11. mysql 假设存在id则设数据自添加1 ,不存在则加入。java月份计算比較
  12. namespace 的作用
  13. Core 2.0 的dll实时更新、https、依赖包变更问题及解决
  14. 2018-11-09 VS Code英汉词典插件v0.0.4-驼峰下划线命名
  15. Codeforces 912C Perun, Ult!
  16. python threading模块使用 以及python多线程操作的实践(使用Queue队列模块)
  17. Python设计模式 - 总览(更新中...)
  18. ubuntu下sudo apt-get update Sources 404 Not Found 解决方法
  19. [整理] mysql操作
  20. javascript基础 思维导图2

热门文章

  1. python 错误:"'NoneType' object has no attribute 'execute'"
  2. [译]Python面试中8个必考问题
  3. phantomjs的使用
  4. d3 画地图终极自适应大小方案
  5. Pandas系列之入门篇——HDF5
  6. linux(七)之linux系统中查找文件
  7. [51nod1610]路径计数
  8. Codeforces Round #336 (Div. 2)-608A.水题 608B.前缀和
  9. UE4 custom depth 自定义深度
  10. Spark算子--union、intersection、subtract