dual表詳解


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表中只返回一條記錄.當然這寫內部操作是不可見的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM