成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle數據庫中重定義表的介紹

數據庫 Oracle
表在Oracle數據庫中的應用是很常見的,表的功能性也是比較好的,應用起來很方便,本文將主要為大家介紹有關Oracle數據庫中在線重定義表的知識。

在線重定義表具有以下功能

  1.   修改表的存儲參數;
  2.   可以將表轉移到其他表空間;
  3.   增加并行查詢選項;
  4.   增加或刪除分區;
  5.   重建表以減少碎片;
  6.   將堆表改為索引組織表或相反的操作;
  7.   增加或刪除一個列。

  調用DBMS_REDEFINITION包需要EXECUTE_CATALOG_ROLE角色,除此之外,還需要CREATE ANY TABLE、ALTER ANY TABLE、DROP ANY TABLE、LOCK ANY TABLE和SELECT ANY TABLE的權限。

在線重定義表的步驟如下:

  1.選擇一種重定義方法:

  存在兩種重定義方法,一種是基于主鍵、另一種是基于ROWID。ROWID的方式不能用于索引組織表,而且重定義后會存在隱藏列M_ROW$$。默認采用主鍵的方式。

  2.調用DBMS_REDEFINITION.CAN_REDEF_TABLE()過程,如果表不滿足重定義的條件,將會報錯并給出原因。

  3.在用一個方案中建立一個空的中間表,根據重定義后你期望得到的結構建立中間表。比如:采用分區表,增加了COLUMN等。

  4.調用DBMS_REDEFINITION.START_REDEF_TABLE()過程,并提供下列參數:被重定義的表的名稱、中間表的名稱、列的映射規則、重定義方法。

  如果映射方法沒有提供,則認為所有包括在中間表中的列用于表的重定義。如果給出了映射方法,則只考慮映射方法中給出的列。如果沒有給出重定義方法,則認為使用主鍵方式。

  5.在中間表上建立觸發器、索引和約束,并進行相應的授權。任何包含中間表的完整性約束應將狀態置為disabled。

  當重定義完成時,中間表上建立的觸發器、索引、約束和授權將替換重定義表上的觸發器、索引、約束和授權。中間表上disabled的約束將在重定義表上enable。

  6.(可選)如果在執行DBMS_REDEFINITION.START_REDEF_TABLE()過程和執行DBMS_REDEFINITION.FINISH_REDEF_TABLE()過程直接在重定義表上執行了大量的DML操作,那么可以選擇執行一次或多次的SYNC_INTERIM_TABLE()過程,以減少最后一步執行FINISH_REDEF_TABLE()過程時的鎖定時間。

  7.執行DBMS_REDEFINITION.FINISH_REDEF_TABLE()過程完成表的重定義。這個過程中,原始表會被獨占模式鎖定一小段時間,具體時間和表的數據量有關。

  執行完FINISH_REDEF_TABLE()過程后,原始表重定義后具有了中間表的屬性、索引、約束、授權和觸發器。中間表上disabled的約束在原始表上處于enabled狀態。

  8.(可選)可以重命名索引、觸發器和約束。對于采用了ROWID方式重定義的表,包括了一個隱含列M_ROW$$。推薦使用下列語句經隱含列置為UNUSED狀態或刪除。

  ALTER TABLE TABLE_NAME SET UNUSED (M_ROW$$);
  ALTER TABLE TABLE_NAME DROP UNUSED COLUMNS;

  下面是進行重定義操作后的結果:

  原始表根據中間表的屬性和特性進行重定義;

  START_REDEF_TABLE()和FINISH_REDEF_TABLE()操作之間在中間表上建立的觸發器、索引、約束和授權,現在定義在原始表上。中間表上disabled的約束在原始表上處于enabled狀態。

  原始表上定義的觸發器、索引、約束和授權建立在中間表上,并會在刪除中間表時刪除。原始表上原來enabled狀態的索引,建立在中間表上,并處于disabled狀態。

  任何定義在原始表上的存儲過程和游標都會變為INVALID,當下次調用時后自動進行編譯。

  如果執行過程中出現錯誤或者人為選擇退出的話,可以執行DBMS_REDEFINITION.ABORT_REDEF_TABLE()過程。

  其中UNAME 參數是指用戶;

上文中介紹的內容都是很基礎的知識,是初學者很好的學習資料,希望大家都能好好學習文中的知識,靈活的掌握。

【編輯推薦】

  1. 講解Oracle數據庫提供的多種安全性措施
  2. Oracle數據庫中表的四種連接方式講解
  3. 復制或遷移Oracle數據庫的最簡單方法

 

責任編輯:迎迎 來源: 希賽網
相關推薦

2010-04-23 14:32:01

Oracle數據庫

2009-05-13 10:28:30

OracleDUAL數據庫

2010-04-15 13:01:25

Oracel數據庫

2010-04-23 11:32:22

Oracle數據庫

2015-10-28 17:39:04

ORACLE AIO異步IO

2011-08-11 15:34:26

Oracle數據庫新增字段在線重定義

2015-10-28 14:45:35

ORACLE AIO異步IO

2010-04-21 14:45:39

Oracle數據庫

2010-04-28 18:25:51

Oracle數據庫

2010-04-20 11:41:55

Oracle數據庫

2010-04-02 12:23:30

Oracle數據庫

2010-05-07 17:39:02

Oracle數據庫性能

2011-08-12 12:59:33

Oracle數據庫同義詞

2010-05-04 11:02:44

Oracle數據庫

2010-04-07 09:31:02

Oracle數據庫

2010-04-23 16:05:50

Oracle數據庫

2010-03-18 09:28:14

Oracle數據庫遷移

2009-08-24 18:09:13

C#調用Oracle數

2011-05-17 13:43:23

Oracle數據庫

2010-10-15 16:20:59

MySQL數據庫表
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产激情毛片 | 亚洲一二三区精品 | 久久精品国产一区 | 黄色av网站在线观看 | www.国产精| av天天操 | 久久成人国产 | 国产精品永久免费视频 | 天天干天天谢 | 日韩精品三区 | 草久网 | 久久精品毛片 | 久久青视频 | 国产精品九九视频 | 欧美日韩三级 | 亚洲视频在线观看 | 成人一级黄色毛片 | 国产日韩欧美精品 | 97伦理电影 | 国产在线观看一区 | 9999视频| 亚洲一区有码 | 免费看国产精品视频 | 一区二区三区久久 | 一区二区三区福利视频 | 欧美黑人激情 | 日韩视频免费看 | 亚洲午夜精品一区二区三区他趣 | 综合久久av | 国产日韩精品久久 | 国产精品无码永久免费888 | 亚洲精品一区二区在线观看 | 欧美精品区 | 国产不卡一区在线观看 | 精品婷婷 | 99爱国产 | 亚洲成人福利视频 | 羞羞涩涩在线观看 | 黄色一级毛片 | 在线观看国产三级 | 国产高清视频一区 |