国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Oracle數(shù)據(jù)庫中的表外鍵的更名細(xì)則

瀏覽:92日期:2023-11-13 11:42:04
Oracle 中表的外鍵是保證系統(tǒng)參照完整性的手段,而參照完整性是指分布在兩個表中的列所滿足的具有主從性質(zhì)的約束關(guān)系。外鍵涉及到兩個表,其中一個稱之為父項表,另一個稱之為子項表。 父項表( parent table )是參照約束的基礎(chǔ),即通過檢查這張表的有效數(shù)據(jù)情況來判定約束是否成立,它是參照約束的條件,影響約束,而不受約束的任何影響。 子項表( child table )是參照約束的對象,當(dāng)其發(fā)生變化,如有新數(shù)據(jù)輸入時,通過比較父項表中的有效數(shù)據(jù)狀況,來判定這些變化是否符合約束條件,若不符合,則拒絕要發(fā)生的變化。 在實際應(yīng)用系統(tǒng)中,開發(fā)者為了保證系統(tǒng)的完整性,一般要定義大量的外鍵。然而,假如外鍵的命名不規(guī)范,如采用系統(tǒng)自動生成的名稱,則在以后的系統(tǒng)運行維護(hù)中會造成很大的麻煩。如在系統(tǒng)運行后,加載大量數(shù)據(jù)或者進(jìn)行一些數(shù)據(jù)轉(zhuǎn)換操作等時,出現(xiàn)外鍵錯誤時,根據(jù)系統(tǒng)提示的外鍵錯誤,根本不可能直接定位到那兩個表間的外鍵發(fā)生錯誤,需要浪費很多時間查找造成錯誤發(fā)生的外鍵的父項表和子項表,然后才能進(jìn)一步確定是那條記錄違反了外鍵約束條件。通常,我們采用這樣的命名規(guī)則來命名外鍵 FK_Child_table name_Parent_table name 。由于外鍵名稱的最大長度限制在 30 個字符之內(nèi),對 child_table_name 和 Parent_table name 不一定和原表一模一樣,可以采取一些簡寫的辦法,但名稱一定要能反映出約束的兩個表。這里的命名, Child_table name 指子項表,也就是約束表, Parent_table name 是指父項表,也就是被約束的表。 下面來具體討論如何將應(yīng)用系統(tǒng)中不規(guī)范的外鍵命名修改為規(guī)范的外鍵名稱。在討論之前,需要提醒讀者注重的是,完成下面的操作需要花費較長的時間,所以一定要規(guī)劃在系統(tǒng)空閑時來完成。同時這里的外鍵更名,采用的方法是首先刪除然后重建,涉及到刪除應(yīng)用系統(tǒng)對象的操作,所以在操作之前,為安全起見,應(yīng)該備份應(yīng)用系統(tǒng)。 一、生成系統(tǒng)目前的外鍵報告單 首先生成系統(tǒng)目前模式下的所有外鍵情況報告單, SQL 腳本如下: 腳本 1 :列出當(dāng)前模式下所有外鍵的報告表,可以將其 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_Name FROM USER_CONSTRAINTS child, USER_CONSTRAINTS parent, USER_CONS_COLUMNS cp, USER_CONS_COLUMNS pc WHERE child.CONSTRAINT_TYPE = 'R' AND child.R_CONSTRAINT_NAME = PARENT.CONSTRAINT_NAME AND child.CONSTRAINT_NAME = cp.CONSTRAINT_NAME AND parent.CONSTRAINT_NAME = pc.CONSTRAINT_NAME AND cp.POSITION = pc.POSITION ORDER BY child.OWNER, child.TABLE_NAME, child.CONSTRAINT_NAME, cp.POSITION;該腳本生成所在模式下的所有外鍵情況,包括外鍵名稱,父項表名稱,子項表名稱以及引用的列名稱等。在 SQL/PLUS 下運行該腳本,在運行該腳本之前,可以將輸出 SPOOL 到本地某個文件中。同時要注重,假如應(yīng)用系統(tǒng)中的外鍵比較多且復(fù)雜的話,這個腳本的運行時間會比較長。 二、生成刪除系統(tǒng)自動命名的外鍵腳本 在 SQL/PLUS 下,運行下面的腳本來生成刪除系統(tǒng)自動命名(也就是外鍵名稱以 SYS 為前綴)的所有外鍵,和生成外鍵報告一樣,將生成腳本 spool 到某個文件中。 腳本 2 :刪除系統(tǒng)自動生成的外鍵約束條件 SELECT 'ALTER TABLE ' TABLE_NAME ' ' 'DROP CONSTRAINT ' CONSTRAINT_NAME ' ;' FROM USER_CONSTRAINTS WHERE CONSTRAINT_NAME LIKE 'SYS%' AND CONSTRAINT_TYPE = 'R';運行該腳本,系統(tǒng)生成如下所示的刪除外鍵腳本: ALTER TABLE DJ_NSRXX DROP CONSTRAINT SYS_C000231;三、生成重新創(chuàng)建刪除的外鍵腳本 在 SQL/PLUS 下,運行下面的腳本來生成重新創(chuàng)建刪除的外鍵腳本: 腳本 3 :重新創(chuàng)建外鍵 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 pc WHERE child.CONSTRAINT_TYPE = 'R' AND child.R_OWNER = PARENT.OWNER AND child.R_CONSTRAINT_NAME = PARENT.CONSTRAINT_NAME AND child.CONSTRAINT_NAME = cp.CONSTRAINT_NAME AND parent.CONSTRAINT_NAME = pc.CONSTRAINT_NAME AND cp.POSITION = pc.POSITION AND child.CONSTRAINT_NAME LIKE 'SYS%' ORDER BY child.OWNER, child.TABLE_NAME, child.CONSTRAINT_NAME, cp.POSITION;運行該腳本,系統(tǒng)生成如下所示的創(chuàng)建外鍵腳本: ALTER TABLE DJ_NSRXX ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);將上面的外鍵名稱以上面介紹的規(guī)范命名規(guī)則命名的外鍵名稱代替,就是: ALTER TABLE DJ_NSRXX ADD CONSTRAINT FK_DJ_NSRXX_DM_GY_SWRY FOREIGN KEY (RYDM) REFERENCES DM_GY_SWRY(RYDM);四、外鍵更名 生成上面的兩個腳本后,首先運行第二步中刪除系統(tǒng)自動生成外鍵的腳本,將系統(tǒng)中命名不規(guī)范的外鍵刪除,然后運行第三步中生成的創(chuàng)建外鍵的腳本,重新創(chuàng)建這些刪除的外鍵,也就實現(xiàn)了對不規(guī)范外鍵的更名。 五、系統(tǒng)檢查 操作完成后,重新執(zhí)行步驟 1 ,再生成一個應(yīng)用系統(tǒng)的外鍵報告單,作對比檢查。假如正確無誤,則更名成功,否則查找原因。
標(biāo)簽: Oracle 數(shù)據(jù)庫
主站蜘蛛池模板: 广东毛片 | 91看片淫黄大片欧美看国产片 | 欧美成人se01短视频在线看 | 热99re久久国超精品首页 | 亚洲欧美一区二区三区久本道 | 国产成人一区二区视频在线观看 | 国产成人女人在线视频观看 | 亚洲欧美日韩另类精品一区二区三区 | 有码 在线 | 亚洲精品自拍视频 | 欧美高清在线精品一区 | a级片免费观看视频 | 日本三级中文字幕 | 欧美一区二区在线播放 | 国产精品视频成人 | 欧美在线观看a | 69xx欧美| 美女三级毛片 | 亚洲成人在线视频播放 | 亚洲欧美一区二区久久 | 国产日产亚洲系列首页 | 欧美成人精品一区二区三区 | 欧美一级做一级爱a做片性 欧美一欧美一级毛片 | 99精品视频在线观看 | 深夜爽爽福利gif在线观看 | 久草免费资源在线 | 岛国大片在线播放免费 | 在线a毛片免费视频观看 | 嫩草影院在线观看网站成人 | 伊人久久青草青青综合 | 一区二区三区日本视频 | 亚洲乱人伦精品图片 | 欧美精品一级毛片 | 成人精品视频网站 | 美女扒开腿让男生桶爽网站 | 欧美精品不卡 | 6080伦理久久亚洲精品 | 欧美黄色高清 | avtom影院入口永久在线观看 | 欧美成人午夜片一一在线观看 | 香港三级日本三级人妇三级四 |