oracle 中的dual

问:Oracle的dual是什么东西啊

Oracle的dual是什么东西啊,我原来以为是一张表,但是看到很多时候都有from dual,如下:
select concat('010-','88888888')||'转23' 高乾竞电话 from dual;
select * from dual;有没有什么记录,请帮忙解答,谢谢!

 

答:1. dual 确实是一张表.是一张只有一个字段,一行记录的表. 2.习惯上,我们称之为'伪表'.因为他不存储主题数据. 3. 他的存在,是为了操作上的方便.因为select 都是要有特定对象的. 如:select * from mytable ; select * from myview; 等等. 但如果我们不需要从具体的表来取得表中数据,而是单纯地为了得到一些我们想得到的信息,并要通过select 完成时,就要借助一个对象,这个对象,就是dual; 如我们要计算 999*999 的值,可以用: select 999*999 from dual; 来实现; 要拼接一个电话信息: select concat('010-','88888888')||'转23' 高乾竞电话 from dual; 就变成了我们想要的格式输出. 4.当然,我们不一定要dual ,也可以这样做.例如: create table mydual( dummy varchar2(1)); 也可以实现和dual 同样的效果: select 999*999 from mydual; 不过,dual 我们都用习惯了,就无谓自己再搞一套了.

原文地址:https://www.cnblogs.com/SEEKTHINKING/p/2020645.html