成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

瀏覽:164日期:2023-11-13 11:42:04
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 。由于外鍵名稱的最大長(zhǎng)度限制在 30 個(gè)字符之內(nèi),對(duì) child_table_name 和 Parent_table name 不一定和原表一模一樣,可以采取一些簡(jiǎn)寫的辦法,但名稱一定要能反映出約束的兩個(gè)表。這里的命名, Child_table name 指子項(xiàng)表,也就是約束表, Parent_table name 是指父項(xiàng)表,也就是被約束的表。 下面來具體討論如何將應(yīng)用系統(tǒng)中不規(guī)范的外鍵命名修改為規(guī)范的外鍵名稱。在討論之前,需要提醒讀者注重的是,完成下面的操作需要花費(fèi)較長(zhǎng)的時(shí)間,所以一定要規(guī)劃在系統(tǒng)空閑時(shí)來完成。同時(shí)這里的外鍵更名,采用的方法是首先刪除然后重建,涉及到刪除應(yīng)用系統(tǒng)對(duì)象的操作,所以在操作之前,為安全起見,應(yīng)該備份應(yīng)用系統(tǒng)。 一、生成系統(tǒng)目前的外鍵報(bào)告單 首先生成系統(tǒng)目前模式下的所有外鍵情況報(bào)告單, SQL 腳本如下: 腳本 1 :列出當(dāng)前模式下所有外鍵的報(bào)告表,可以將其 spool 到某個(gè)文件中 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;該腳本生成所在模式下的所有外鍵情況,包括外鍵名稱,父項(xiàng)表名稱,子項(xiàng)表名稱以及引用的列名稱等。在 SQL/PLUS 下運(yùn)行該腳本,在運(yùn)行該腳本之前,可以將輸出 SPOOL 到本地某個(gè)文件中。同時(shí)要注重,假如應(yīng)用系統(tǒng)中的外鍵比較多且復(fù)雜的話,這個(gè)腳本的運(yùn)行時(shí)間會(huì)比較長(zhǎng)。 二、生成刪除系統(tǒng)自動(dòng)命名的外鍵腳本 在 SQL/PLUS 下,運(yùn)行下面的腳本來生成刪除系統(tǒng)自動(dòng)命名(也就是外鍵名稱以 SYS 為前綴)的所有外鍵,和生成外鍵報(bào)告一樣,將生成腳本 spool 到某個(gè)文件中。 腳本 2 :刪除系統(tǒng)自動(dòng)生成的外鍵約束條件 SELECT 'ALTER TABLE ' TABLE_NAME ' ' 'DROP CONSTRAINT ' CONSTRAINT_NAME ' ;' FROM USER_CONSTRAINTS WHERE CONSTRAINT_NAME LIKE 'SYS%' AND CONSTRAINT_TYPE = 'R';運(yùn)行該腳本,系統(tǒng)生成如下所示的刪除外鍵腳本: ALTER TABLE DJ_NSRXX DROP CONSTRAINT SYS_C000231;三、生成重新創(chuàng)建刪除的外鍵腳本 在 SQL/PLUS 下,運(yùn)行下面的腳本來生成重新創(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;運(yùn)行該腳本,系統(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);四、外鍵更名 生成上面的兩個(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ì)比檢查。假如正確無誤,則更名成功,否則查找原因。
標(biāo)簽: Oracle 數(shù)據(jù)庫
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美在线观看一区| 精东粉嫩av免费一区二区三区| 亚洲va欧美va天堂v国产综合| 亚洲欧美一区在线| 欧美日韩高清一区二区三区| 亚洲女与黑人做爰| 国内成+人亚洲| 国产日韩精品久久久| 成人理论电影网| 欧美久久久久中文字幕| 日韩国产欧美一区二区三区| 亚洲综合不卡| 亚洲综合色区另类av| 99综合在线| 一区二区三区在线观看欧美| 亚洲成人原创| 亚洲欧美一区二区在线观看| 极品少妇一区二区三区| 国产欧美一区二区三区沐欲 | 亚洲一区二区黄色| 亚洲精品欧洲精品| 中文字幕亚洲在| 最新日韩av| 亚洲黄色免费电影| 国产精品久久久久久模特 | 日韩视频一区二区在线观看| 国产**成人网毛片九色| 欧美va亚洲va| 91浏览器打开| 国产精品久久毛片| 亚洲精品乱码久久久久久蜜桃91| 中文字幕在线一区免费| 在线精品一区二区| 一区二区三区在线看| 久久精品91| 久久精品国产久精国产爱| 欧美精品在线观看一区二区| 粉嫩一区二区三区性色av| 2023国产精品| 狠狠久久综合婷婷不卡| 夜夜精品视频一区二区 | 久久精品在这里| 欧美片网站免费| 亚洲三级小视频| 销魂美女一区二区三区视频在线| 亚洲1区2区3区4区| 欧美日韩一二三区| 成人黄色av网站在线| 中文一区在线播放 | 欧美一区二区观看视频| 91影视在线播放| 亚洲免费资源在线播放| 日本精品一区二区三区高清 | 国产日韩欧美高清免费| 奇米色777欧美一区二区| 欧美一级生活片| 欧美午夜免费| 亚洲午夜视频在线| 欧美片网站yy| 欧美日韩精品久久| 亚洲gay无套男同| 欧美肥大bbwbbw高潮| 欧美在线91| 一区二区三区高清| 欧美日韩国产123区| 99久久er热在这里只有精品15| 亚洲视频资源在线| 色狠狠av一区二区三区| 波多野洁衣一区| 亚洲影视在线播放| 欧美一级在线视频| 亚洲国产一区二区三区a毛片| 日韩精品乱码免费| 精品国产一区二区三区忘忧草| 136国产福利精品导航网址| 免费av成人在线| 久久久久久日产精品| 久久国产精品久久久久久电车 | 日韩视频不卡| 精品伊人久久久久7777人| 337p日本欧洲亚洲大胆色噜噜| 日韩视频二区| 国产精品91一区二区| 国产精品久久久久久久蜜臀| 欧美综合一区二区三区| 欧美va天堂在线| 日韩中文字幕av电影| 欧美一级在线视频| 亚洲少妇一区| 国产成人在线观看免费网站| 亚洲欧美电影一区二区| 欧美日本免费一区二区三区| 红桃视频亚洲| 六月丁香婷婷久久| 中文一区二区在线观看| 欧美中文字幕不卡| 欧美尤物一区| 麻豆成人免费电影| 国产精品久久久久婷婷二区次| 欧美日韩中文国产| 亚洲黄色大片| 丁香另类激情小说| 亚洲小说欧美激情另类| 精品国产伦一区二区三区免费| 欧美资源在线| 欧美在线网站| 另类小说图片综合网| 亚洲欧洲日产国码二区| 制服.丝袜.亚洲.中文.综合| 国产日韩专区| av电影在线观看一区| 日韩高清在线观看| 国产精品久久久久久亚洲伦| 91精品国产色综合久久不卡蜜臀| 国产亚洲网站| 91丝袜国产在线播放| 日韩av中文字幕一区二区三区| 国产网红主播福利一区二区| 欧美日韩一区二区三区在线| 亚洲精华国产欧美| 国产91在线看| 日本不卡1234视频| 亚洲精品菠萝久久久久久久| 26uuu精品一区二区| 欧美三级日本三级少妇99| 亚洲看片一区| 91女神在线视频| 国产乱子轮精品视频| 日韩精品每日更新| 一区二区三区四区av| 国产欧美精品一区二区三区四区 | 亚洲午夜激情| 成人精品免费视频| 日本美女一区二区三区视频| 亚洲日本青草视频在线怡红院 | 亚洲一区av在线| 国产亚洲成年网址在线观看| 欧美精品自拍偷拍| 快she精品国产999| 国产欧美91| 欧美性大战久久久久| 成人开心网精品视频| 乱一区二区av| 日韩在线一区二区三区| 一区二区视频在线| 国产精品国产a| 久久嫩草精品久久久久| 这里只有精品免费| 欧美午夜影院一区| 久久xxxx精品视频| 国产欧美日本在线| 一区二区亚洲| 午夜欧美精品| 成人精品视频一区| 国产精品亚洲午夜一区二区三区| 美女看a上一区| 亚洲成人黄色小说| 亚洲资源在线观看| 一区二区三区免费| 亚洲精品亚洲人成人网| **性色生活片久久毛片| 欧美国产丝袜视频| 久久久激情视频| 精品国产91洋老外米糕| 日韩三级视频在线看| 91精品国产综合久久小美女| 在线精品视频小说1| 久久电影一区| 亚洲在线不卡| 一本色道88久久加勒比精品| 99精品国产高清一区二区| 亚洲国产一区二区精品专区| 国内精品美女在线观看| 欧美日韩综合网| 国内自拍亚洲| 伊人精品成人久久综合软件| 影音国产精品| 亚洲人久久久| 国产欧美日韩亚洲一区二区三区| 中文亚洲字幕| 久久aⅴ国产紧身牛仔裤| 久久本道综合色狠狠五月| 免费看亚洲片| 久久综合影视| 色婷婷亚洲综合| 欧美午夜精品一区二区三区| 欧美色网一区二区| 7878成人国产在线观看| 欧美一区二区视频免费观看| 日韩欧美在线影院| 精品国产网站在线观看| 久久精品夜色噜噜亚洲aⅴ| 久久你懂得1024| 国产三级一区二区| 成人欧美一区二区三区| 亚洲激情六月丁香| 亚洲成人1区2区| 青草国产精品久久久久久| 极品少妇一区二区| 成人免费福利片|