dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录。我们可以用它来做很多事情,如下:

1、查看当前用户

1 SQL> select user from dual;
2 USER
3 ------------------------------
4 SYSTEM

2、用来调用系统函数

1 --获得当前系统时间
 2 select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
 3 
 4 --获得主机名
 5 select SYS_CONTEXT('USERENV','TERMINAL') from dual;
 6 
 7 --获得当前locale
 8 select SYS_CONTEXT('USERENV','language') from dual;
 9 
10 --获得一个随机数
11 select dbms_random.random from dual;

3、可以用做计算器

1 SQL> select 1+2 from dual;
2 1+2
3 ----------
4 3

4、查看序列值

1 SQL> create sequence aaa increment by 1 start with 1;
 2 SQL> select aaa.nextval from dual;
 3 NEXTVAL
 4 ----------
 5 1
 6 
 7 SQL> select aaa.currval from dual;
 8 CURRVAL
 9 ----------
10 1

彩蛋:

  1. 查询Dual是什么Object?
1 SQL> connect system/manager
2 Connected.
3
4 SQL> select owner, object_name , object_type from dba_objects where object_name like '%DUAL%'; OWNER OBJECT_NAME OBJECT_TYPE
5 --------------- --------------- -------------
6 SYS DUAL TABLE PUBLIC DUAL SYNONYM

原来DUAL是属于SYS schema的一个表,然后以PUBLIC SYNONYM的方式供其他数据库USER使用。

  1. 查询Dual的结构和数据
1 SQL> desc dual Name Null? Type
2 ----------------------------------------- -------- ----------------------
3 DUMMY VARCHAR2(1)

只有一个名字叫DUMMY的字符型COLUMN。

然后查询一下表里的数据:

1 SQL> select dummy from dual;
2 DUMMY
3 ----------
4 X
  1. Dual的奇妙之处

插入一条记录:

1 SQL> connect sys as sysdba
2 Connected.
3
4 SQL> insert into dual values ( 'Y');
5 1 row created.
6
7 SQL> commit;
8 Commit complete.
9
10 SQL> select count(*) from dual;
11 COUNT(*)
12 ----------
13 2

再次查询记录时,奇怪的事情发生了:

1 SQL> select * from dual;
2 DUMMY
3 ----------
4 X

刚才插入的那条记录并没有显示出来 ! 明明DUAL表中有两条记录, 可就是只显示一条!

再试一下删除 ,狠一点,全删光!再查询

1 SQL> delete from dual; /*注意没有限定条件,试图删除全部记录*/
2 1 row deleted.    -- 只有一条记录被删掉
3
4 SQL> commit;
5 Commit complete.
6
7 SQL> select * from dual;
8 DUMMY
9 ----------
10 Y

原来ORACLE对DUAL表的操作做了一些内部处理,尽量保证DUAL表中只返回一条记录.当然这写内部操作是不可见的。

最后修改:2021 年 11 月 17 日
如果觉得我的文章对你有用,请随意赞赏