Oracle 閃回表實驗

來源:互聯網
上載者:User

標籤:閃回表   oracle   收集統計資訊   

作業:閃回表實驗

1.構造測試表flb_test,資料不小於10000行;

[email protected]>create table flb_test(id number,dd date);

Table created.

[email protected]>begin
  2  for i in 1..10000
  3  loop
  4  insert into flb_test values (i,sysdate+i);
  5  end loop;
  6  end;
  7  /

PL/SQL procedure successfully completed.

exec dbms_stats.gather_table_stats(‘TEST_USER1‘,‘FLB_TEST‘);
 --收集統計資訊


2.查詢目前時間與scn號;

[email protected]>select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) from dual;

TO_CHAR(SYSDATE,‘YY
-------------------
2014-10-13 19:23:29

[email protected]>select dbms_flashback.get_system_change_number from dual;

GET_SYSTEM_CHANGE_NUMBER
------------------------
                 1144357

3.查看該測試表block數目及大小M;

[email protected]>select SEGMENT_NAME,BYTES/1024/1024 size_m, BLOCKS from user_segments   
  2  where SEGMENT_NAME=‘FLB_TEST‘;

SEGMENT_NAME        SIZE_M     BLOCKS
--------------- ---------- ----------
FLB_TEST               .25         32


4.在這張表的第一和第二列上,建立一個複合索引ind_flb;

[email protected]>create index ind_flb on flb_test(id,dd);

Index created.

5.查看該索引的葉子塊的數目以及層數;

[email protected]>select INDEX_NAME,STATUS ,BLEVEL,LEAF_BLOCKS from dba_indexes 
  2  where index_name =‘IND_FLB‘;

INDEX_NAME                     STATUS       BLEVEL LEAF_BLOCKS
------------------------------ -------- ---------- -----------
IND_FLB                        VALID             1          33

   --平衡樹:  高度=層數+1

[email protected]>select SEGMENT_NAME,BYTES/1024/1024 size_m, BLOCKS from user_segments
  2  where SEGMENT_NAME=‘FLB_TEST‘;

SEGMENT_NAME        SIZE_M     BLOCKS
--------------- ---------- ----------
FLB_TEST               .25         32


6.刪除測試表中一半的記錄數並提交;

[email protected]>delete from flb_test where id<=5000;

5000 rows deleted.

[email protected]>commit;

Commit complete.

[email protected]>select count(*) from flb_test;

  COUNT(*)
----------
      5000

[email protected]>exec dbms_stats.gather_table_stats(‘TEST_USER1‘,‘FLB_TEST‘);

PL/SQL procedure successfully completed.

[email protected]>exec dbms_stats.gather_index_stats(‘TEST_USER1‘,‘IND_FLB‘);

PL/SQL procedure successfully completed.
    --收集表和索引的統計資訊

7.閃回fls_test到第二步查詢到的時間點;

[email protected]>select table_name ,row_movement from user_tables;

TABLE_NAME                     ROW_MOVE
------------------------------ --------
SALARY                         ENABLED
SYS_TEMP_FBT                   DISABLED
FLB_TEST                       DISABLED
EMP                            DISABLED

[email protected]>alter table flb_test enable row movement;

Table altered.

[email protected]>select table_name ,row_movement from user_tables;

TABLE_NAME                     ROW_MOVE
------------------------------ --------
EMP                            DISABLED
FLB_TEST                       ENABLED
SYS_TEMP_FBT                   DISABLED
SALARY                         ENABLED

[email protected]>flashback table flb_test to timestamp to_timestamp(‘2014-10-13 19:23:29‘,‘yyyy-mm-dd hh24:mi:ss‘);

Flashback complete.


[email protected]>exec dbms_stats.gather_table_stats(‘TEST_USER1‘,‘FLB_TEST‘);

PL/SQL procedure successfully completed.

[email protected]>exec dbms_stats.gather_index_stats(‘TEST_USER1‘,‘IND_FLB‘);

PL/SQL procedure successfully completed.
    --收集表和索引的統計資訊
    --Oracle只是閃回表,所有的東西都原樣保留,應重新收集統計資訊


8.查看閃回結果,以及索引狀態;

[email protected]>select count(*) from flb_test;

  COUNT(*)
----------
     10000

[email protected]>select INDEX_NAME,STATUS ,BLEVEL,LEAF_BLOCKS from dba_indexes
  2  where index_name =‘IND_FLB‘;

INDEX_NAME                     STATUS       BLEVEL LEAF_BLOCKS
------------------------------ -------- ---------- -----------
IND_FLB                        VALID             1          33

 

 

Oracle 閃回表實驗

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.