自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

DUAL是真實的表嗎

數(shù)據(jù)庫 Oracle
DUAL:Diffusing Update Algorithm ,彌散更新算法.EIGRP組件之一。dual是Oracle與數(shù)據(jù)字典一起自動創(chuàng)建的一個虛擬表。

DUAL是真實的表,還是優(yōu)化器對DUAL的引用進行特別處理?

結(jié)論:是真實的表,見以下分析。

同時,根據(jù)建庫腳本$ORACLE_HOME/RDBMS/ADMIN/dcore.bsq,優(yōu)化器對該表有特殊處理,具體如何處理沒有詳細說明。

1 執(zhí)行計劃

  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與數(shù)據(jù)字典一起自動創(chuàng)建的一個虛擬表﹐它只有一列﹕DUMMY﹐其數(shù)據(jù)類型為﹕VARCHAR2(1)。dual中只有一行數(shù)據(jù)﹕ 'X '。dual屬于sys模式﹐但所有用戶都可以使用dual名稱訪問它﹐用SELECT計算常量表達式﹑偽列等值時常用該表﹐因為它只返回一行數(shù)據(jù)﹐而使用其它表時可能返回多個數(shù)據(jù)行。用來查那些不屬于實際表里的內(nèi)容,有時也用來檢查某表某條件的記錄存在性。

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

【編輯推薦】

  1. 告訴你一些DBA求職面試技巧
  2. 這些問題,你能回答多少
  3. 在牛人眼中 數(shù)據(jù)庫有何差異化又該如何選型
  4. Oracle的安全標記算不算bug
  5. 如何抓住蝴蝶效應(yīng)中的那只蝴蝶


   
 

責任編輯:艾婧 來源: ITPUB
相關(guān)推薦

2009-11-17 09:31:06

Oracle Dual

2009-05-13 10:28:30

OracleDUAL數(shù)據(jù)庫

2011-07-05 09:27:54

DUAL表數(shù)據(jù)庫

2015-10-30 14:56:40

真實數(shù)據(jù)欺騙

2010-08-04 11:38:24

Oracle數(shù)據(jù)庫

2024-04-18 08:18:10

電商優(yōu)化單線程

2016-10-25 21:00:27

云計算

2019-07-29 09:20:30

5G基站功耗運營商

2022-01-13 14:31:56

MySQL數(shù)據(jù)庫回表

2021-03-01 11:53:15

面試偽共享CPU

2011-06-13 16:35:54

LBS街旁移動互聯(lián)網(wǎng)

2011-11-15 08:53:52

用戶

2011-04-25 12:49:42

2015-05-19 11:22:36

真實人生修電腦

2021-04-29 10:08:10

數(shù)據(jù)結(jié)構(gòu)哈希表

2010-08-30 09:58:20

虛擬化整合案例

2010-08-26 09:49:57

虛擬化整合案例

2011-11-10 14:21:48

Java

2022-11-22 08:01:30

2017-01-10 09:48:58

PHP語言Perl
點贊
收藏

51CTO技術(shù)棧公眾號