Oracle中的Dual表

Posted shmilywei

tags:

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

1、Dual是Oracle中的一个实际存在的表。是一张只有一个字段,一行记录的表,任何用户均可读取,常用在没有目标表的select语句块中。

2、习惯上,我们称之为“伪表”。因为他不存储主体数据。

3、他的存在,是为了操作上的方便。因为select都是要有特定对象的。

如:select * from mytable;  select * from myview;  等等。

但如果我们不需要从具体的表来取得表中数据,而是单纯地为了得到一些我们想得到的信息,并要通过select完成时,就要借助一个对象,这个对象,就是dual;

如:

      1)返回当前连接的用户,可以用:select user from dual;来实现;

      2)计算999*999的值,可以用:select 999*999 from dual;来实现;

      3)拼接一个电话信息:select concat(‘010-‘,‘88888888‘)||‘转23‘ 高乾竞电话 from dual;

 技术分享图片

就变成了我们想要的格式输出。

4、当然,我们不一定要dual,也可以这样做。例如:

create table mydual(dummy varchar2(1));

也可以实现和dual同样的效果:

select 999*999 from mydual;

不过,Dual我们都用习惯了,就无谓自己再搞一套了。

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

Oracle Dual 表详解

Oracle中的Dual表

Oracle虚表

Oracle中的虚拟表:dual

ORACLE中dual用法详解

Oracle数据库中dual是什么东西啊?