DUAL是真实的表吗

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. 如何抓住蝴蝶效应中的那只蝴蝶

   
 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/227170.html<

(0)
运维的头像运维
上一篇2025-04-17 17:12
下一篇 2025-04-17 17:13

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注