Oracle系統資料表外鍵的更名

來源:互聯網
上載者:User

正在看的ORACLE教程是: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是指父項表,也就是被約束的表。

  下面來詳細討論如何將應用系統中不規範的外鍵命名修改為規範的外鍵名稱。在討論之前,需要提醒讀者注意的是,完成下面的操作需要花費較長的時間,所以一定要規劃在系統空閑時來完成。同時這裡的外鍵更名,採用的方法是首先刪除然後重建,涉及到刪除應用系統對象的操作,所以在操作之前,為安全起見,應該備份應用系統。

[NextPage]

 一、產生系統目前的外鍵報告單

  首先產生系統目前模式下的所有外鍵情況報告單,SQL指令碼如下:

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

  二、產生刪除系統自動命名的外鍵指令碼

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

  運行該指令碼,系統產生如下所示的刪除外鍵指令碼:
三、產生重新建立刪除的外鍵指令碼

  在SQL/PLUS下,運行下面的指令碼來產生重新建立刪除的外鍵指令碼:

  運行該指令碼,系統產生如下所示的建立外鍵指令碼:

  ALTER TABLE DJ_NSRXX ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);

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

  四、外鍵更名

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

  五、系統檢查

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

上一頁

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.