前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Oracle基础之保留字和关键字

Oracle基础之保留字和关键字

作者头像
SmileNicky
发布2020-01-13 15:19:17
1.2K0
发布2020-01-13 15:19:17
举报
文章被收录于专栏:Nicky's blogNicky's blog

Oracle基础之保留字和关键字

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

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

查询Oracle保留字SQL:

代码语言:javascript
复制
  SELECT * FROM v$reserved_words m WHERE m.RESERVED='Y'

我测试的是Oracle11.2版本,有100条记录

在这里插入图片描述
在这里插入图片描述

Oracle中的关键字就多了,Oracle11.2版本有1730条记录,Oracle关键字查询SQL:

代码语言:javascript
复制
    SELECT * FROM v$reserved_words m WHERE m.RESERVED='N';
在这里插入图片描述
在这里插入图片描述

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

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

比如我insert一条数据:

代码语言:javascript
复制
insert into A(KEY,DESC) values('TEST_KEY','这是一个key值');

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

代码语言:javascript
复制
insert into A(KEY,"DESC") values('TEST_KEY','这是一个key值');

而在MySQL中也是有保留字和关键字的说法,不过解决方法是加上 ` 符号,比如

代码语言:javascript
复制
insert into A(`KEY`,`DESC`) values('TEST_KEY','这是一个key值');
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-01-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档