• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    數據庫進階:如何將Oracle數據庫的普通表轉換成分區表

    發布: 2008-5-13 11:08 | 作者: GOD | 來源: 希賽網 | 查看: 67次 | 進入軟件測試論壇討論

    領測軟件測試網 優點:

      只是對數據字典中分區和表的定義進行了修改,沒有數據的修改或復制,效率最高。如果對數據在分區中的分布沒有進一步要求的話,實現比較簡單。在執行完RENAME操作后,可以檢查T_OLD中是否存在數據,如果存在的話,直接將這些數據插入到T中,可以保證對T插入的操作不會丟失。

      不足:

      仍然存在一致性問題,交換分區之后RENAME T_NEW TO T之前,查詢、更新和刪除會出現錯誤或訪問不到數據。如果要求數據分布到多個分區中,則需要進行分區的SPLIT操作,會增加操作的復雜度,效率也會降低。
      適用于包含大數據量的表轉到分區表中的一個分區的操作。應盡量在閑時進行操作。

      方法三:Oracle9i以上版本,利用在線重定義功能

      步驟:

      SQL> CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE);

      表已創建。

      SQL> INSERT INTO T SELECT ROWNUM, CREATED FROM DBA_OBJECTS;

      已創建6264行。

      SQL> COMMIT;

      提交完成。

      SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(USER’, 'T', DBMS_REDEFINITION.CONS_USE_PK);
      PL/SQL 過程已成功完成。
      SQL> CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME)
      2 (PARTITION P1 VALUES LESS THAN (TO_DATE('2004-7-1', 'YYYY-MM-DD')),
      3 PARTITION P2 VALUES LESS THAN (TO_DATE('2005-1-1', 'YYYY-MM-DD')),
      4 PARTITION P3 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')),
      5 PARTITION P4 VALUES LESS THAN (MAXVALUE));

      表已創建。

      SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(‘USER’, 'T', 'T_NEW', -
      > 'ID ID, TIME TIME', DBMS_REDEFINITION.CONS_USE_PK);
      可以改為:
      SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(‘USER’, 'T', 'T_NEW')
      PL/SQL 過程已成功完成。
      SQL> EXEC dbms_redefinition.sync_interim_table(‘USER’, 'T', 'T_NEW')
      現在,將中間表與原始表同步。(僅當要對表 T 進行更新時才需要執行該操作。)
      SQL> EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(USER’, 'T', 'T_NEW');
      PL/SQL 過程已成功完成。

      如果重組織失敗,那么你就必須采取特殊的步驟來讓它重新開始。由于重定義過程需要創建表格的快照,因此為了重新開始這一過程,你必須調用DBMS_REDEFINITION.ABORT_REDEF_TABLE來釋放快照。

      DBMS_REDEFINITION.ABORT_REDEF_TABLE過程有三個參數,即用戶(schema)、原始表格(original table name)名稱以及持有表格名稱(holding table name)。它“出!辈⒃试S你開始重組織表格。

      SQL> SELECT COUNT(*) FROM T;
      SQL> SELECT COUNT(*) FROM T PARTITION (P2);
      SQL> SELECT COUNT(*) FROM T PARTITION (P3);

      需要說明的是完成后,原表和中間表的結構也同時進行了交換,并且中間表里面有原表的數據備份。

      優點:

      保證數據的一致性,在大部分時間內,表T都可以正常進行DML操作。只在切換的瞬間鎖表,具有很高的可用性。這種方法具有很強的靈活性,對各種不同的需要都能滿足。而且,可以在切換前進行相應的授權并建立各種約束,可以做到切換完成后不再需要任何額外的管理操作。

      不足:實現上比上面兩種略顯復雜,適用于各種情況。

      然而,在線表格重定義也不是完美無缺的。下面列出了Oracle9i重定義過程的部分限制:

      你必須有足以維護兩份表格拷貝的空間。
      你不能更改主鍵欄。
      表格必須有主鍵。
      必須在同一個大綱中進行表格重定義。
      在重定義操作完成之前,你不能對新加欄加以NOT NULL約束。
      表格不能包含LONG、BFILE以及用戶類型(UDT)。
      不能重定義鏈表(clustered tables)。
      不能在SYS和SYSTEM大綱中重定義表格。
      不能用具體化視圖日志(materialized view logs)來重定義表格;不能重定義含有具體化視圖的表格。
      不能在重定義過程中進行橫向分集(horizontal subsetting)。

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    33/3<123

    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備2023014753號-2
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>