亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

Oracle數據庫中的表外鍵的更名細則

2024-08-29 13:50:47
字體:
來源:轉載
供稿:網友
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_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 到本地某個文件中。同時要注重,假如應用系統中的外鍵比較多且復雜的話,這個腳本的運行時間會比較長。 二、生成刪除系統自動命名的外鍵腳本 在 SQL/PLUS 下,運行下面的腳本來生成刪除系統自動命名(也就是外鍵名稱以 SYS 為前綴)的所有外鍵,和生成外鍵報告一樣,將生成腳本 spool 到某個文件中。 腳本 2 :刪除系統自動生成的外鍵約束條件
SELECT 'ALTER TABLE ' TABLE_NAME ' ' 'DROP CONSTRAINT ' CONSTRAINT_NAME ' ;' FROM USER_CONSTRAINTS WHERE CONSTRAINT_NAME LIKE 'SYS%' AND CONSTRAINT_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 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;
運行該腳本,系統生成如下所示的創建外鍵腳本:
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 ,再生成一個應用系統的外鍵報告單,作對比檢查。假如正確無誤,則更名成功,否則查找原因。


上一篇:關于Oracle數據庫中快照的使用方法

下一篇:有時Oracle不用索引來查找數據的原因

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一本一道久久a久久精品逆3p| 久久免费视频观看| 亚洲最新视频在线| 97人人爽人人喊人人模波多| 久久久久久成人精品| 91在线高清视频| 国产成人精品在线观看| 中文国产亚洲喷潮| 久久精品成人一区二区三区| 欧美电影电视剧在线观看| 欧美激情xxxx性bbbb| 日韩精品视频在线播放| 97精品久久久| 日韩精品免费在线视频观看| 狠狠色噜噜狠狠狠狠97| 久久综合五月天| 日韩国产精品亚洲а∨天堂免| 久久久精品视频在线观看| 亚洲人成电影在线观看天堂色| 国产精品手机播放| 日本a级片电影一区二区| 欧美wwwxxxx| 97久久久免费福利网址| 精品国产鲁一鲁一区二区张丽| 日韩在线视频免费观看| 国产一区二区三区视频| 亚洲国产精品嫩草影院久久| 欧美电影免费观看大全| 久久香蕉精品香蕉| 欧美成人免费大片| 国产综合久久久久久| 日本久久久久久久| 亚洲欧洲日韩国产| 狠狠色香婷婷久久亚洲精品| 国内揄拍国内精品少妇国语| 久久人人看视频| 久久精品国产精品亚洲| 亚洲精品视频二区| 国产日韩专区在线| 国产性色av一区二区| 日本久久中文字幕| 91精品国产高清自在线看超| 日韩在线观看网站| 国产精品丝袜高跟| 国产成人+综合亚洲+天堂| 久久久久久综合网天天| 欧美国产日韩二区| 全色精品综合影院| 中文字幕免费国产精品| 亚洲视频在线免费观看| 日本中文字幕不卡免费| 亚洲香蕉伊综合在人在线视看| 亚洲欧美制服中文字幕| 国产精品99免视看9| 性色av一区二区三区红粉影视| 26uuu亚洲伊人春色| 国产精自产拍久久久久久| 久久久999国产| 性欧美视频videos6一9| 久久精品国产欧美激情| 色综合伊人色综合网站| 91探花福利精品国产自产在线| 久久久国产在线视频| 日韩高清电影免费观看完整版| 欧美激情一区二区三区在线视频观看| 欧美成人sm免费视频| 俺去了亚洲欧美日韩| 国产精品高清网站| 亚洲**2019国产| 6080yy精品一区二区三区| 91免费看国产| 成人妇女免费播放久久久| 色多多国产成人永久免费网站| 在线看日韩欧美| 久久亚洲私人国产精品va| 欧美与欧洲交xxxx免费观看| 亚洲国产精品久久久久秋霞蜜臀| 91精品视频在线| 丝袜一区二区三区| 亚洲曰本av电影| 欧美贵妇videos办公室| 精品国偷自产在线视频| 久久久久久国产| 久久中文久久字幕| 国产97色在线| 欧美午夜www高清视频| 中文字幕一区日韩电影| 亚洲毛片在线观看| 国产精品mp4| 久久影视电视剧免费网站清宫辞电视| 日韩视频在线免费| 久久久国产一区二区三区| 日韩在线观看免费全集电视剧网站| 性欧美激情精品| 亚洲欧美日韩精品| 久久国产精品影视| 777777777亚洲妇女| 国产精品2018| 亚洲国产中文字幕久久网| 日韩av电影中文字幕| 国模极品一区二区三区| 亚洲国产精品va| 91高清视频免费观看| 国产女精品视频网站免费| 4438全国成人免费| 国产原创欧美精品| 久久黄色av网站| 日韩欧美一区二区在线| 精品久久久久久中文字幕大豆网| 一区二区三区视频免费| 国产成人av网| 少妇高潮 亚洲精品| 色婷婷av一区二区三区在线观看| 欧美裸体xxxx极品少妇| 精品国产乱码久久久久久婷婷| 亚洲日本成人女熟在线观看| 97成人在线视频| 97精品欧美一区二区三区| 久久天天躁夜夜躁狠狠躁2022| 啪一啪鲁一鲁2019在线视频| 欧美三级欧美成人高清www| 欧洲亚洲女同hd| 亚洲电影免费观看高清完整版| 欧美福利在线观看| 精品中文字幕在线2019| 狠狠操狠狠色综合网| 97国产精品视频人人做人人爱| 欧美成人午夜激情在线| 欧美丰满少妇xxxxx做受| 国产精品成久久久久三级| 欧美日韩国产成人高清视频| 亚洲欧美激情视频| 亚洲精品久久久久国产| 成人精品一区二区三区电影免费| 国产综合久久久久久| 日韩亚洲欧美成人| 国产综合在线观看视频| 亚洲国产中文字幕久久网| 欧美日韩中文字幕日韩欧美| 久久精品视频一| 国产成人免费91av在线| 热久久免费视频精品| 中文字幕欧美国内| 97涩涩爰在线观看亚洲| 日韩亚洲综合在线| 久久视频在线视频| 亚洲成色777777女色窝| 97国产精品免费视频| 欧美插天视频在线播放| 国产精品尤物福利片在线观看| 日韩成人网免费视频| 亚洲一区二区三区xxx视频| 午夜精品久久久久久久久久久久久| 亚洲男人天堂手机在线| 精品视频—区二区三区免费| 日韩成人在线观看| 欧美日韩亚洲网| 国产精品女主播视频| 久久这里只有精品视频首页| 欧美大片在线看免费观看| 北条麻妃在线一区二区| 日韩av在线天堂网| 国内精品久久久久久| 久久久www成人免费精品|