日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:204日期:2023-11-13 11:42:04
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 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
麻豆精品久久| 正在播放日韩精品| 亚洲激情另类| 免费视频亚洲| 亚洲国产成人精品女人| 国产专区一区| 美女国产精品| 四虎精品一区二区免费| 日本一区中文字幕| 日韩精品成人| 国产劲爆久久| 国产极品模特精品一二| 美日韩一区二区三区| 精品一区不卡| 日韩在线不卡| 激情婷婷久久| 男人的天堂亚洲一区| 蜜臀久久99精品久久久画质超高清 | 日韩一区二区三区免费| 福利视频一区| 99久久99视频只有精品| 中文字幕在线视频网站| 久久精品国产99久久| 久久国产精品久久w女人spa| 蜜桃视频在线观看一区二区| 日韩美女精品| 免费视频一区二区三区在线观看| 成人午夜在线| 激情综合网址| 四虎成人精品一区二区免费网站| 久久只有精品| 成人免费电影网址| 性色一区二区| 欧美视频精品全部免费观看| 国产一区二区三区国产精品| 久久亚洲精品中文字幕蜜潮电影| 99久久亚洲精品| 亚洲激情精品| 国产欧美日韩在线一区二区 | 亚洲制服欧美另类| 国产精品亚洲综合色区韩国| 成人看片网站| 日韩中文字幕1| 久久精品二区亚洲w码| 婷婷丁香综合| 欧美日韩夜夜| 久久激情一区| 亚洲毛片视频| 国产资源在线观看入口av| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲精品大片| 蜜桃av在线播放| 亚洲免费毛片| 亚洲va中文在线播放免费| 一区二区精品| 国产 日韩 欧美 综合 一区| 手机精品视频在线观看| 国产精一区二区| 国产主播一区| 免费日韩成人| 亚洲专区在线| 日本在线啊啊| 国产亚洲精品美女久久 | 在线视频免费在线观看一区二区| 国产精品久久久久久久免费软件| 影视先锋久久| 久久精品999| 好看的av在线不卡观看| 久久精品国产99国产精品| 日韩亚洲国产欧美| 精品国产18久久久久久二百| 激情综合网站| 久久不见久久见免费视频7| 亚洲欧美日韩高清在线| 国产精品扒开腿做爽爽爽软件| 伊人影院久久| 天堂av在线| 日韩和欧美一区二区三区| 久久一区二区三区电影| 欧美国产日本| 一区二区亚洲视频| 99久久精品费精品国产| 另类综合日韩欧美亚洲| 亚洲综合中文| 怡红院精品视频在线观看极品| jizzjizz中国精品麻豆| 国产日韩亚洲欧美精品| 亚洲有吗中文字幕| 欧美在线资源| 成人美女视频| 免费精品一区| 国产精品一区二区美女视频免费看| 婷婷丁香综合| 韩国精品主播一区二区在线观看 | 精品国产精品国产偷麻豆| 久久一二三区| 久久精品高清| 日韩久久精品网| 超碰99在线| 日本一二区不卡| 久久伊人久久| 国产精品一区高清| 日韩在线视频一区二区三区| 99在线精品免费视频九九视| 国产91一区| 国产伦久视频在线观看| 久久99久久人婷婷精品综合| 日韩精品国产欧美| 国产99久久久国产精品成人免费| 伊伊综合在线| 捆绑调教日本一区二区三区| 精品国产午夜肉伦伦影院| 国产精品主播| 国产精品嫩模av在线| 亚洲制服少妇| 亚洲一区二区三区高清不卡| 亚洲一区二区三区四区五区午夜| 日韩午夜av| 丝袜美腿高跟呻吟高潮一区| 亚洲免费精品| 日韩午夜精品| 视频一区国产视频| 蜜桃久久精品一区二区| 欧美中文字幕| 亚洲欧美一级| 久久精品超碰| 久久久久久久久成人| 久久99国产精品视频| 麻豆91在线播放| 国产在视频一区二区三区吞精| 久久一区国产| 中文字幕在线看片| 999精品在线| 亚洲大全视频| 丝袜美腿亚洲色图| 午夜精品影视国产一区在线麻豆| 日韩国产精品久久久| 国产精品一线| 国产一区国产二区国产三区| 日韩免费视频| 亚洲精品97| 一区二区日韩免费看| 国产欧美一区二区精品久久久| 老司机免费视频一区二区| 韩国久久久久久| 欧美日韩国产免费观看视频| 在线综合亚洲| 欧美日韩精品一区二区三区在线观看| 欧美日韩中出| 手机在线电影一区| 女主播福利一区| 亚洲精品伊人| 久久中文字幕一区二区三区| 久久九九精品| 免费人成在线不卡| 国产精品亚洲综合久久| 国产一区不卡| 狠狠干成人综合网| 日韩高清在线不卡| 久久久久伊人| 亚洲电影在线一区二区三区| 亚洲a成人v| 精品久久影院| 伊人成人网在线看| 国产精品久久久久久久久久齐齐 | 国产精品嫩草99av在线| 婷婷综合福利| 久久男人av| 国产在线不卡| 国产日韩亚洲欧美精品| 欧美gv在线| 亚洲视频电影在线| 麻豆视频一区| 不卡一区2区| 欧美一区影院| 欧美片第1页| 日本不卡高清| 福利在线免费视频| 综合激情在线| 日本а中文在线天堂| 最近国产精品视频| 福利在线免费视频| 蜜桃视频免费观看一区| 老鸭窝一区二区久久精品| 亚洲黄色影院| 黄色精品视频| 综合干狼人综合首页| 成人污污视频| 日本亚洲欧洲无免费码在线| 亚洲伦乱视频| 国产剧情在线观看一区| 欧美午夜不卡| 97精品国产| 久久激情av| 99国产精品久久久久久久成人热| 国产精品www.| 亚洲青青久久| 999国产精品视频| 欧美精品第一区| 久久最新视频|