Oracle系統(tǒng)表外鍵的更名
Oracle中表的外鍵是保證系統(tǒng)參照完整性的手段,而參照完整性是指分布在兩個(gè)表中的列所滿足的具有主從性質(zhì)的約束關(guān)系。外鍵涉及到兩個(gè)表,其中一個(gè)稱之為父項(xiàng)表,另一個(gè)稱之為子項(xiàng)表。
父項(xiàng)表(parent table)是參照約束的基礎(chǔ),即通過檢查這張表的有效數(shù)據(jù)情況來判斷約束是否成立,它是參照約束的條件,影響約束,而不受約束的任何影響。
子項(xiàng)表(child table)是參照約束的對(duì)象,當(dāng)其發(fā)生變化,如有新數(shù)據(jù)輸入時(shí),通過比較父項(xiàng)表中的有效數(shù)據(jù)狀況,來判斷這些變化是否符合約束條件,若不符合,則拒絕要發(fā)生的變化。
在實(shí)際應(yīng)用系統(tǒng)中,開發(fā)者為了保證系統(tǒng)的完整性,一般要定義大量的外鍵。然而,如果外鍵的命名不規(guī)范,如采用系統(tǒng)自動(dòng)生成的名稱,則在以后的系統(tǒng)運(yùn)行維護(hù)中會(huì)造成很大的麻煩。如在系統(tǒng)運(yùn)行后,加載大量數(shù)據(jù)或者進(jìn)行一些數(shù)據(jù)轉(zhuǎn)換操作等時(shí),出現(xiàn)外鍵錯(cuò)誤時(shí),根據(jù)系統(tǒng)提示的外鍵錯(cuò)誤,根本不可能直接定位到那兩個(gè)表間的外鍵發(fā)生錯(cuò)誤,需要浪費(fèi)很多時(shí)間查找造成錯(cuò)誤發(fā)生的外鍵的父項(xiàng)表和子項(xiàng)表,然后才能進(jìn)一步確定是那條記錄違反了外鍵約束條件。通常,我們采用這樣的命名規(guī)則來命名外鍵FK_Child_table name_Parent_table name。由于外鍵名稱的最大長度限制在30個(gè)字符之內(nèi),對(duì)child_table_name和Parent_table name不一定和原表一模一樣,可以采取一些簡寫的辦法,但名稱一定要能反映出約束的兩個(gè)表。這里的命名,Child_table name指子項(xiàng)表,也就是約束表,Parent_table name是指父項(xiàng)表,也就是被約束的表。
下面來詳細(xì)討論如何將應(yīng)用系統(tǒng)中不規(guī)范的外鍵命名修改為規(guī)范的外鍵名稱。在討論之前,需要提醒讀者注意的是,完成下面的操作需要花費(fèi)較長的時(shí)間,所以一定要規(guī)劃在系統(tǒng)空閑時(shí)來完成。同時(shí)這里的外鍵更名,采用的方法是首先刪除然后重建,涉及到刪除應(yīng)用系統(tǒng)對(duì)象的操作,所以在操作之前,為安全起見,應(yīng)該備份應(yīng)用系統(tǒng)。
[NextPage]
一、生成系統(tǒng)目前的外鍵報(bào)告單
首先生成系統(tǒng)目前模式下的所有外鍵情況報(bào)告單,SQL腳本如下:
該腳本生成所在模式下的所有外鍵情況,包括外鍵名稱,父項(xiàng)表名稱,子項(xiàng)表名稱以及引用的列名稱等。在SQL/PLUS下運(yùn)行該腳本,在運(yùn)行該腳本之前,可以將輸出SPOOL到本地某個(gè)文件中。同時(shí)要注意,如果應(yīng)用系統(tǒng)中的外鍵比較多且復(fù)雜的話,這個(gè)腳本的運(yùn)行時(shí)間會(huì)比較長。
二、生成刪除系統(tǒng)自動(dòng)命名的外鍵腳本
在SQL/PLUS下,運(yùn)行下面的腳本來生成刪除系統(tǒng)自動(dòng)命名(也就是外鍵名稱以SYS為前綴)的所有外鍵,和生成外鍵報(bào)告一樣,將生成腳本spool到某個(gè)文件中。
運(yùn)行該腳本,系統(tǒng)生成如下所示的刪除外鍵腳本:
三、生成重新創(chuàng)建刪除的外鍵腳本
在SQL/PLUS下,運(yùn)行下面的腳本來生成重新創(chuàng)建刪除的外鍵腳本:
運(yùn)行該腳本,系統(tǒng)生成如下所示的創(chuàng)建外鍵腳本:
ALTER TABLE DJ_NSRXX ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);
將上面的外鍵名稱以上面介紹的規(guī)范命名規(guī)則命名的外鍵名稱代替,就是
四、外鍵更名
生成上面的兩個(gè)腳本后,首先運(yùn)行第二步中刪除系統(tǒng)自動(dòng)生成外鍵的腳本,將系統(tǒng)中命名不規(guī)范的外鍵刪除,然后運(yùn)行第三步中生成的創(chuàng)建外鍵的腳本,重新創(chuàng)建這些刪除的外鍵,也就實(shí)現(xiàn)了對(duì)不規(guī)范外鍵的更名。
五、系統(tǒng)檢查
操作完成后,重新執(zhí)行步驟1,再生成一個(gè)應(yīng)用系統(tǒng)的外鍵報(bào)告單,作對(duì)比檢查。如果正確無誤,則更名成功,否則查找原因。
上一頁
相關(guān)文章
oracle—SQL技巧之(一)連續(xù)記錄查詢sql案例測試
有這樣一個(gè)需求:需要查詢出某個(gè)客戶某一年那些天是有連續(xù)辦理過業(yè)務(wù),本文給予sql實(shí)現(xiàn)語句并測試,感興趣的朋友可以了解下2013-01-01oracle中的ID號(hào)實(shí)現(xiàn)自增長的方法
這篇文章主要介紹了oracle中的ID號(hào)如何實(shí)現(xiàn)自增長,利用序列產(chǎn)生主鍵值,需要的朋友可以參考下2014-05-05linux下oracle設(shè)置開機(jī)自啟動(dòng)實(shí)現(xiàn)方法
你會(huì)發(fā)現(xiàn)Oracle沒有自行啟動(dòng),這是正常的,因?yàn)樵贚inux下安裝Oracle的確不會(huì)自行啟動(dòng),必須要自行設(shè)定相關(guān)參數(shù),首先先介紹一般而言如何啟動(dòng)oracle2012-11-11