Oracle系統表外來鍵的更名

2022-02-07 20:40:24 字數 1547 閱讀 6856

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指令碼如下:

該指令碼生成所在模式下的所有外來鍵情況,包括外來鍵名稱,父項表名稱,子項表名稱以及引用的列名稱等。在sql/plus下執行該指令碼,在執行該指令碼之前,可以將輸出spool到本地某個檔案中。同時要注意,如果應用系統中的外來鍵比較多且複雜的話,這個指令碼的執行時間會比較長。

在sql/plus下,執行下面的指令碼來生成刪除系統自動命名(也就是外來鍵名稱以sys為字首)的所有外來鍵,和生成外來鍵報告一樣,將生成指令碼spool到某個檔案中。

執行該指令碼,系統生成如下所示的刪除外來鍵指令碼:

在sql/plus下,執行下面的指令碼來生成重新建立刪除的外來鍵指令碼:

執行該指令碼,系統生成如下所示的建立外來鍵指令碼:

1

alter

table dj_nsrxx add

constraint 外來鍵名稱 foreign

key (rydm) references dm_gy_swry(rydm);

將上面的外來鍵名稱以上面介紹的規範命名規則命名的外來鍵名稱代替,就是

生成上面的兩個指令碼後,首先執行第二步中刪除系統自動生成外來鍵的指令碼,將系統中命名不規範的外來鍵刪除,然後執行第三步中生成的建立外來鍵的指令碼,重新建立這些刪除的外來鍵,也就實現了對不規範外來鍵的更名。

操作完成後,重新執行步驟1,再生成乙個應用系統的外來鍵報告單,作對比檢查。如果正確無誤,則更名成功,否則查詢原因。

Oracle 查詢所有表外來鍵

查詢表的外來鍵 包括名稱,引用表的表名和對應的鍵名,下面是分成多步查詢 select from user constraints c where c.constraint type r and c.table name 要查詢的表查詢外來鍵約束的列名 select from user cons co...

Oracle的表操作 外來鍵約束

1 外來鍵約束 外來鍵 foreign key 是用來建立和加強兩個表資料之間的連線的一列或多列。外來鍵約束是唯一涉及兩個表關係的約束。注 先建立的表叫主表或附表,後建立的且和主表有關係的表叫從表或子表 2 外來鍵約束的注意事項 1 設定外來鍵約束時主表的字段必須是主鍵列 或唯一列 2 主從表中相應...

Oracle表中新增外來鍵約束

新增主鍵約束 alter table ga airline add constraint pk airline id primary key airline id 有三種形式的外來鍵約束 1 普通外來鍵約束 如果存在子表引用父表主鍵,則無法刪除父表記錄 2 級聯外來鍵約束 可刪除存在引用的父表記錄,...