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使用。
2. 查询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
3. 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表中只返回一条记录.当然这写内部操作是不可见的。