Oracle基础之保留字和关键字

Posted SmileNicky的博客

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle基础之保留字和关键字相关的知识,希望对你有一定的参考价值。

Oracle基础之保留字和关键字

在Oracle之中,有分为保留字和关键字,所谓关键字就是Oracle中有实际意义的,而保留字(比如DESC、ORDER等等)是Oracle中不能随便使用的,比如不能随便用来做表的列名,当然关键字(比如KEY等等)也是不推荐的,不过使用的话是不会报错的,而保留字被使用不当的话是会报错的

然后如何区分保留字和关键字?Oracle中可以通过查询v$reserved_words表得知

查询Oracle保留字SQL:

  SELECT * FROM v$reserved_words m WHERE m.RESERVED='Y'

我测试的是Oracle11.2版本,有100条记录
技术图片
Oracle中的关键字就多了,Oracle11.2版本有1730条记录,Oracle关键字查询SQL:

    SELECT * FROM v$reserved_words m WHERE m.RESERVED='N';

技术图片

虽然Oracle官方是不推荐保留字和关键字来使用的,比如被用于做表的列名,不过还是会被使用,我就曾遇到过

比如表A有列(KEY(key值),DESC(描述)),这个就是一个很不规范的命名,其中KEY是Oracle的关键字,不推荐使用,但是还是不会报错的,而DESC就是一个保留字了,使用的话是会报错的

比如我insert一条数据:

insert into A(KEY,DESC) values('TEST_KEY','这是一个key值');

执行之后,是会报错的,解决方法是针对保留字DESC加上双引号

insert into A(KEY,"DESC") values('TEST_KEY','这是一个key值');

而在mysql中也是有保留字和关键字的说法,不过解决方法是加上 符号,比如 ```sql insert into A(KEY,DESC`) values(‘TEST_KEY‘,‘这是一个key值‘);
```

以上是关于Oracle基础之保留字和关键字的主要内容,如果未能解决你的问题,请参考以下文章

oracle数据库基础知识汇总—30天

mysql保留关键字的一个小知识

oracle 中怎么样去除关键字特殊意义?

javascript基础 之 保留关键字

关键字和保留字

基础快速过 之C语言 二:什么是关键字 标识符 系统保留字 变量和常量[各个语言通用]