DUAL是真实的表吗

数据库 Oracle
DUAL:Diffusing Update Algorithm ,弥散更新算法.EIGRP组件之一。dual是Oracle与数据字典一起自动创建的一个虚拟表。

DUAL是真实的表,还是优化器对DUAL的引用进行特别处理?

结论:是真实的表,见以下分析。

同时,根据建库脚本$ORACLE_HOME/RDBMS/ADMIN/dcore.bsq,优化器对该表有特殊处理,具体如何处理没有详细说明。

1 执行计划

  1. select * from dual;  
  2.  
  3. Plan hash value: 272002086  
  4.    
  5. --------------------------------------------------------------------------  
  6. | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |  
  7. --------------------------------------------------------------------------  
  8. |   0 | SELECT STATEMENT  |      |     1 |     2 |     2   (0)| 00:00:01 |  
  9. |   1 |  TABLE ACCESS FULL| DUAL |     1 |     2 |     2   (0)| 00:00:01 | 

2 rowid

  1. select dbms_rowid.rowid_object(rowid) obj,  
  2.        dbms_rowid.rowid_relative_fno(rowid) rfno,  
  3.        dbms_rowid.rowid_block_number(rowid) bno,  
  4.        dbms_rowid.rowid_row_number(rowid) rno from dual;  
  5.         
  6. OBJ RFNO BNO RNO  
  7. 258 1 2082 0        
  8.  
  9. select owner,object_name,object_id from dba_objects where object_id=258;  
  10. OWNER OBJECT_NAME OBJECT_ID  
  11. SYS DUAL 258 

3,dump block

  1. alter system dump datafile 1 block 2082;  
  2. --------------------------------------------------  
  3. /u01/app/oracle/product/10.2.0/db_1/admin/bocnet/udump/bocnet_ora_557.trc  
  4. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production  
  5. With the Partitioning, OLAP and Data Mining options  
  6. ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1  
  7. System name: Linux  
  8. Node name: bocnet95  
  9. Release: 2.6.18-164.el5xen  
  10. Version: #1 SMP Thu Sep 3 04:47:32 EDT 2009  
  11. Machine: i686  
  12. Instance name: bocnet  
  13. Redo thread mounted by this instance: 1  
  14. Oracle process number: 50  
  15. Unix process pid: 557, image:oracle@bocnet95(TNS V1-V3)  
  16.  
  17. *** SERVICE NAME:(SYS$USERS) 2011-05-29 04:54:44.485  
  18. *** SESSION ID:(135.9121) 2011-05-29 04:54:44.485  
  19. Start dump data blocks tsn: 0 file#: 1 minblk 2082 maxblk 2082  
  20. buffer tsn: 0 rdba: 0x00400822 (1/2082)  
  21. scn: 0x0006.c428013f seq: 0x01 flg: 0x04 tail: 0x013f0601  
  22. frmt: 0x02 chkval: 0x89a3 type: 0x06=trans data  
  23. Hex dump of block: st=0, typ_found=1  
  24. Dump of memory from 0x0D6D0400 to 0x0D6D2400  
  25. D6D0400 0000A206 00400822 C428013F 04010006  [....".@.?.(.....]  
  26. D6D0410 000089A3 00000001 00000102 A514474A  [............JG..]  
  27. D6D0420 00000001 00030002 00000000 00200009  [.............. .]  
  28. D6D0430 00003DF2 00820CFC 00070E84 00018000  [.=..............]  
  29. D6D0440 A41874A9 00230001 00004CA9 00800C2F  [.t....#..L../...]  
  30. D6D0450 002A1137 0001A000 A513B6E3 00010100  [7.*.............]  
  31. D6D0460 0014FFFF 1F831F9B 00001F83 1F9B0001  [................]  
  32. D6D0470 00000000 00000000 00000000 00000000  [................]  
  33.         Repeat 503 times  
  34. D6D23F0 00000000 2C000000 58010100 013F0601  [.......,...X..?.]  
  35. Block header dump:  0x00400822  
  36.  Object id on Block? Y  
  37.  seg/obj: 0x102  csc: 0x01.a514474a  itc: 2  flg: O  typ: 1 - DATA  
  38.      fsl: 0  fnx: 0x0 ver: 0x01  
  39.    
  40.  Itl           Xid                  Uba         Flag  Lck        Scn/Fsc  
  41. 0x01   0x0009.020.00003df2  0x00820cfc.0e84.07  C---    0  scn 0x0001.a41874a9  
  42. 0x02   0x0001.023.00004ca9  0x00800c2f.1137.2a  C-U-    0  scn 0x0001.a513b6e3  
  43.    
  44. data_block_dump,data header at 0xd6d045c  
  45. ===============  
  46. tsiz: 0x1fa0  
  47. hsiz: 0x14  
  48. pbl: 0x0d6d045c  
  49. bdba: 0x00400822  
  50.      76543210  
  51. flag=--------  
  52. ntab=1  
  53. nrow=1  
  54. frre=-1  
  55. fsbo=0x14  
  56. fseo=0x1f9b  
  57. avsp=0x1f83  
  58. tosp=0x1f83  
  59. 0xe:pti[0] nrow=1 offs=0  
  60. 0x12:pri[0] offs=0x1f9b  
  61. block_row_dump:  
  62. tab 0, row 0, @0x1f9b  
  63. tl: 5 fb: --H-FL-- lb: 0x0  cc: 1  
  64. col  0: [ 1]  58  
  65. end_of_block_dump  
  66. End dump data blocks tsn: 0 file#: 1 minblk 2082 maxblk 2082  
  67. --------------------------------------------------- 

4 手工建库脚本

  1. $ORACLE_HOME/RDBMS/ADMIN/dcore.bsq  
  2. --dual  
  3. create table dual                   /* pl/sql's standard pckg requires dual. */  
  4.   (dummy varchar2(1))    /* note, the optimizer knows sys.dual is single row */  
  5.   storage (initial 1)  
  6. /  
  7. insert into dual values('X')  
  8. /  
  9. create public synonym dual for dual  
  10. /  

【延伸扩展】DUAL是什么?

DUAL:Diffusing Update Algorithm ,弥散更新算法.EIGRP组件之一。dual是Oracle与数据字典一起自动创建的一个虚拟表﹐它只有一列﹕DUMMY﹐其数据类型为﹕VARCHAR2(1)。dual中只有一行数据﹕ 'X '。dual属于sys模式﹐但所有用户都可以使用dual名称访问它﹐用SELECT计算常量表达式﹑伪列等值时常用该表﹐因为它只返回一行数据﹐而使用其它表时可能返回多个数据行。用来查那些不属于实际表里的内容,有时也用来检查某表某条件的记录存在性。

  1. 如:select sysdate from dual;     
  2. select 3+3 from dual;     
  3. 相当与Sql Server的     
  4. set @Date=getdate() 

【编辑推荐】

  1. 告诉你一些DBA求职面试技巧
  2. 这些问题,你能回答多少
  3. 在牛人眼中 数据库有何差异化又该如何选型
  4. Oracle的安全标记算不算bug
  5. 如何抓住蝴蝶效应中的那只蝴蝶


   
 

责任编辑:艾婧 来源: ITPUB
相关推荐

2009-11-17 09:31:06

Oracle Dual

2009-05-13 10:28:30

OracleDUAL数据库

2011-07-05 09:27:54

DUAL表数据库

2010-08-04 11:38:24

Oracle数据库

2015-10-30 14:56:40

2016-10-25 21:00:27

云计算

2024-04-18 08:18:10

电商优化单线程

2019-07-29 09:20:30

5G基站功耗运营商

2022-01-13 14:31:56

MySQL数据库回表

2021-03-01 11:53:15

面试伪共享CPU

2011-06-13 16:35:54

LBS街旁移动互联网

2011-04-25 12:49:42

2017-01-10 09:48:58

PHP语言Perl

2018-07-27 14:17:32

2022-01-10 07:27:04

DataOps数据驱动

2021-04-29 10:08:10

数据结构哈希表

2010-08-30 09:58:20

虚拟化整合案例

2010-08-26 09:49:57

虚拟化整合案例

2011-11-15 08:53:52

2015-05-19 11:22:36

真实人生修电脑
点赞
收藏

51CTO技术栈公众号