Oracle虚表

Posted

tags:

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

Oracle数据库中存在一个特别的表dual,它是一个虚拟表,用来构成select的语法规则。Oracle对dual虚表的操作做了一些特别的处理,保证dual表里面永远只有一条记录。dual虚表存在给程序员带来了一些方便。

一、测试dual虚表

dual虚表只有一个字段,有一条记录。

1、dual虚表的结构

技术图片

2、查询dual虚表中的记录

技术图片

3、对dual虚表做增、删、改操作

普通用户对dual虚表只有查询权限,没有增、删、改的权限。DBA对dual虚表有全部的权限,但是,我不建议采用DBA对dual虚表进行操作,没什么意义,大家可以玩玩,但是,某些操作(删除表)可能造成数据库无法启动,请慎重,一定不能在生产环境中折腾。

技术图片

二、dual虚表的用途

利用dual虚表可以调用Oracle的函数和获取序列生成器的值,虽然还可以用来做一些其它的事情,比如说计算,但是对程序员来说利用dual虚表做计算毫无意义。

1、执行Oracle的函数

1)查看当前登录用户。

技术图片

2、获取数据库的日期时间

技术图片

2、获取序列生成器的值

create sequence SEQ_FREECPLUS;         -- 创建序列生成器SEQ_FREECPLUS。
select SEQ_FREECPLUS.nextval from dual;  -- 从序列SEQ_FREECPLUS获取下一个值。
select SEQ_FREECPLUS.currval from dual;  -- 从序列SEQ_FREECPLUS获取当前值。

细心的读者可能会思考一个问题,在insert和update语句中,可以把序列生成器直接填写到SQL语句中,不需要dual虚表。不一定,在实际开发中,可能要把序列生成器的值取出来,比如说参与运算。

三、版权声明

C语言技术网原创文章,转载请说明文章的来源、作者和原文的链接。
来源:C语言技术网(www.freecplus.net)
作者:码农有道

如果这篇文章对您有帮助,请点赞支持,或在您的博客中转发我的文章,谢谢!!!
如果文章有错别字,或者内容有错误,或其他的建议和意见,请您留言指正,非常感谢!!!

以上是关于Oracle虚表的主要内容,如果未能解决你的问题,请参考以下文章

sql Oracle代码片段

Oracle 游标

数据库2生成txt/xml文件,ftp,oracle安装/表操作/虚表/日期/序列,索引/视图/链路/同义词/高可用性,mysql,文件入库/清理/结构设计/交换/收集

如何在 Toad for Oracle 中使用自定义代码片段?

Client / Server Interoperability Support Matrix for Different Oracle Versions (Doc ID 207303.1)(代码片段

c++虚表学习2