Oracle系統中表外來鍵的更名(轉)
Oracle中表的外來鍵是保證系統參照完整性的手段,而參照完整性是指分佈在兩個表中的列所滿足的具有主從性質的約束關係。外來鍵涉及到兩個表,其中一個稱之為父項表,另一個稱之為子項表。
父項表(parent table)是參照約束的基礎,即透過檢查這張表的有效資料情況來判斷約束是否成立,它是參照約束的條件,影響約束,而不受約束的任何影響。
子項表(child table)是參照約束的物件,當其發生變化,如有新資料輸入時,透過比較父項表中的有效資料狀況,來判斷這些變化是否符合約束條件,若不符合,則拒絕要發生的變化。
在實際應用系統中,開發者為了保證系統的完整性,一般要定義大量的外來鍵。然而,如果外來鍵的命名不規範,如採用系統自動生成的名稱,則在以後的系統執行維護中會造成很大的麻煩。如在系統執行後,載入大量資料或者進行一些資料轉換操作等時,出現外來鍵錯誤時,根據系統提示的外來鍵錯誤,根本不可能直接定位到那兩個表間的外來鍵發生錯誤,需要浪費很多時間查詢造成錯誤發生的外來鍵的父項表和子項表,然後才能進一步確定是那條記錄違反了外來鍵約束條件。通常,我們採用這樣的命名規則來命名外來鍵FK_Child_table name_Parent_table name。由於外來鍵名稱的最大長度限制在30個字元之內,對child_table_name和Parent_table name不一定和原表一模一樣,可以採取一些簡寫的辦法,但名稱一定要能反映出約束的兩個表。這裡的命名,Child_table name指子項表,也就是約束表,Parent_table name是指父項表,也就是被約束的表。
下面來詳細討論如何將應用系統中不規範的外來鍵命名修改為規範的外來鍵名稱。在討論之前,需要提醒讀者注意的是,完成下面的操作需要花費較長的時間,所以一定要規劃在系統空閒時來完成。同時這裡的外來鍵更名,採用的方法是首先刪除然後重建,涉及到刪除應用系統物件的操作,所以在操作之前,為安全起見,應該備份應用系統。
一、生成系統目前的外來鍵報告單
首先生成系統目前模式下的所有外來鍵情況報告單,SQL指令碼如下:
******************************************************************************指令碼1:列出當前模式下所有外來鍵的報告表,可以將其spool到某個檔案中******************************************************************************/SELECT RPAD(child.TABLE_NAME,25,' ') Child_Tablename,RPAD(cp.COLUMN_NAME,17,' ') Referring_Column,RPAD(parent.TABLE_NAME,25,' ') Parent_Tablename,RPAD(pc.COLUMN_NAME,15,' ') Referred_Column,RPAD(child.CONSTRAINT_NAME,25,' ') Constraint_NameFROM USER_CONSTRAINTS child,USER_CONSTRAINTS parent,USER_CONS_COLUMNS cp,USER_CONS_COLUMNS pcWHERE child.CONSTRAINT_TYPE = 'R' ANDchild.R_CONSTRAINT_NAME = PARENT.CONSTRAINT_NAME ANDchild.CONSTRAINT_NAME = cp.CONSTRAINT_NAME ANDparent.CONSTRAINT_NAME = pc.CONSTRAINT_NAME ANDcp.POSITION = pc.POSITIONORDER BY child.OWNER,child.TABLE_NAME,child.CONSTRAINT_NAME,cp.POSITION;
該指令碼生成所在模式下的所有外來鍵情況,包括外來鍵名稱,父項表名稱,子項表名稱以及引用的列名稱等。在SQL/PLUS下執行該指令碼,在執行該指令碼之前,可以將輸出SPOOL到本地某個檔案中。同時要注意,如果應用系統中的外來鍵比較多且複雜的話,這個指令碼的執行時間會比較長。
二、生成刪除系統自動命名的外來鍵指令碼
在SQL/PLUS下,執行下面的指令碼來生成刪除系統自動命名(也就是外來鍵名稱以SYS為字首)的所有外來鍵,和生成外來鍵報告一樣,將生成指令碼spool到某個檔案中。
******************************************************************************指令碼2:刪除系統自動生成的外來鍵約束條件******************************************************************************/SELECT 'ALTER TABLE ' || TABLE_NAME ||' '||'DROP CONSTRAINT ' || CONSTRAINT_NAME || ' ;'FROM USER_CONSTRAINTSWHERE CONSTRAINT_NAME LIKE 'SYS%' ANDCONSTRAINT_TYPE = 'R';
執行該指令碼,系統生成如下所示的刪除外來鍵指令碼:
ALTER TABLE DJ_NSRXX DROP CONSTRAINT SYS_C000231;
三、生成重新建立刪除的外來鍵指令碼
在SQL/PLUS下,執行下面的指令碼來生成重新建立刪除的外來鍵指令碼:
******************************************************************************指令碼3:重新建立外來鍵******************************************************************************/SELECT 'ALTER TABLE ' || child.TABLE_NAME||' ' ||'ADD CONSTRAINT ' || '外來鍵名稱 ' ||' '||'FOREIGN KEY ' || '('|| cp.COLUMN_NAME || ')' ||' '|| 'REFERENCES ' || parent.TABLE_NAME ||' '||'('|| pc.COLUMN_NAME || ')'|| child.DELETE_RULE || ' ;'FROM USER_CONSTRAINTS child,USER_CONSTRAINTS parent,USER_CONS_COLUMNS cp,USER_CONS_COLUMNS pcWHERE child.CONSTRAINT_TYPE = 'R' ANDchild.R_OWNER = PARENT.OWNER ANDchild.R_CONSTRAINT_NAME = PARENT.CONSTRAINT_NAME ANDchild.CONSTRAINT_NAME = cp.CONSTRAINT_NAME ANDparent.CONSTRAINT_NAME = pc.CONSTRAINT_NAME ANDcp.POSITION = pc.POSITION ANDchild.CONSTRAINT_NAME LIKE 'SYS%'ORDER BY child.OWNER,child.TABLE_NAME,child.CONSTRAINT_NAME,cp.POSITION;
執行該指令碼,系統生成如下所示的建立外來鍵指令碼:
ALTER TABLE DJ_NSRXX ADD CONSTRAINT 外來鍵名稱 FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);
將上面的外來鍵名稱以上面介紹的規範命名規則命名的外來鍵名稱代替,就是
ALTER TABLE DJ_NSRXX ADD CONSTRAINT FK_DJ_NSRXX_DM_GY_SWRY FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);
四、外來鍵更名
生成上面的兩個指令碼後,首先執行第二步中刪除系統自動生成外來鍵的指令碼,將系統中命名不規範的外來鍵刪除,然後執行第三步中生成的建立外來鍵的指令碼,重新建立這些刪除的外來鍵,也就實現了對不規範外來鍵的更名。
五、系統檢查
操作完成後,重新執行步驟1,再生成一個應用系統的外來鍵報告單,作對比檢查。如果正確無誤,則更名成功,否則查詢原因。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10748419/viewspace-954146/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle 外來鍵查詢sqlOracleSQL
- oracle外來鍵約束的總結Oracle
- Oracle 外來鍵的級聯處理Oracle
- Oracle根據主鍵查詢外來鍵Oracle
- MYSQL的外來鍵MySql
- Oracle '批量'禁用外來鍵的儲存過程Oracle儲存過程
- Oracle查詢表的外來鍵引用關係Oracle
- Oracle外來鍵約束中NULL的處理OracleNull
- mysql中的外來鍵MySql
- sqlserver外來鍵SQLServer
- 關於 oracle 外來鍵引用 與 goldengateOracleGo
- Oracle定義約束 外來鍵約束Oracle
- Oracle 外來鍵索引影響阻塞問題Oracle索引
- 父表修改與外來鍵的關係(主鍵DML與外來鍵的關係)
- (轉)oracle資料庫中所有外來鍵約束失效SQL語句Oracle資料庫SQL
- Oracle 9i中表的線上重定義(轉)Oracle
- indexedDB 內鍵與外來鍵Index
- oracle查詢表資訊(索引,外來鍵,列等)Oracle索引
- ORACLE 禁用/啟用外來鍵和觸發器Oracle觸發器
- 小議Oracle外來鍵約束脩改行為(七)Oracle
- 小議Oracle外來鍵約束脩改行為(六)Oracle
- 小議Oracle外來鍵約束脩改行為(五)Oracle
- 小議Oracle外來鍵約束脩改行為(四)Oracle
- 小議Oracle外來鍵約束脩改行為(三)Oracle
- 小議Oracle外來鍵約束脩改行為(二)Oracle
- 小議Oracle外來鍵約束脩改行為(一)Oracle
- SQL的主鍵和外來鍵約束SQL
- 外來鍵技術
- 新的主鍵和外來鍵的語法
- [轉]oracle的系統表Oracle
- 【實驗】【外來鍵】小議外來鍵約束對應用程式的影響
- 顯示資料庫中表的主鍵資料庫
- 批量修改欄位長度,考慮主鍵外來鍵索引的情況【轉】索引
- 聊聊 Webpack 外掛系統的關鍵實現 TapableWeb
- ORACLE: 查詢(看)表的主鍵、外來鍵、唯一性約束和索引Oracle索引
- [轉] mysql 外來鍵(Foreign Key)的詳解和例項MySql
- oracle中查詢、禁用、啟用、刪除表外來鍵Oracle
- oracle外來鍵索引解決父表鎖定問題Oracle索引