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我们都用习惯了,就无谓自己再搞一套了。

猜你喜欢

转载自www.cnblogs.com/shmilyWei/p/9028565.html