0514-86177077
9:00-17:00(工作日)
作為一個Oracle數(shù)據(jù)庫管理員,會碰到這樣的數(shù)據(jù)庫管理需求,停止或者打開當前用戶(模式)下所有表的約束條件和觸發(fā)器。這在數(shù)據(jù)庫的合并以及對數(shù)據(jù)庫系統(tǒng)的代碼表中某些代碼的修改時需要做的工作之一。 我們來看這樣一種實際數(shù)據(jù)庫工作業(yè)務需求,這在目前的許多應用中是非常實際的。某地區(qū)銀行數(shù)據(jù),目前采用市級數(shù)據(jù)集中,隨著計算機網(wǎng)絡技術(shù)的不斷提高以及對服務水平的要求,提出了省級乃至國家級的數(shù)據(jù)集中。除了應用需要修改以外,對于數(shù)據(jù)庫管理員來講,最重要的工作就是對各地分散管理的數(shù)據(jù)庫統(tǒng)一集中到一個或者幾個集中數(shù)據(jù)庫中。此時就需要整理以前各地各自為政的代碼表為一個統(tǒng)一的代碼表以及數(shù)據(jù)庫的最后集中合并。 對Oracle數(shù)據(jù)庫管理員來講,這樣的數(shù)據(jù)維護工作,在更新代碼表中代碼或者合并數(shù)據(jù)之前,首先要作的工作就是將系統(tǒng)中某用戶下所有的外鍵或觸發(fā)器停止,處理完數(shù)據(jù)后,再打開這些關閉的外鍵和觸發(fā)器。針對這樣的工作需求,本文給出了下面兩個SQL腳本:(1) 系統(tǒng)中某模式或用戶下外鍵或者觸發(fā)器的管理腳本;(2) 外鍵錯誤自動查找腳本。下面就來詳細介紹這兩個腳本。 一、約束管理腳本 該腳本可用來管理當前登錄用戶下的所有外鍵和觸發(fā)器的打開和關閉,此處沒有處理主鍵和唯一約束條件,該腳本稍加修改就可以處理主鍵和唯一約束條件,但這里建議最好不要在隨意停止主鍵或唯一約束條件后,進行數(shù)據(jù)維護。 腳本運行方法如下(SQL/PLUS): 其中,參數(shù)as_alter只能是“ENABLE”或者“DISABLE”,否則程序提示錯誤。當參數(shù)為“ENABLE”時,表示將當前模式下所有的外鍵和觸發(fā)器打開,相反“DISABLE”就是將當前模式下所有的外鍵和觸發(fā)器關閉。 附存儲過程腳本: 判斷輸入?yún)?shù)是否為DISABLE或者是ENABLE,如果是的話,就繼續(xù)處理,否則退出過程,給出提示 IF (UPPER(AS_ALTER) = 'DISABLE' OR UPPER(AS_ALTER) = 'ENABLE') THEN OPEN C_CON;
PL/SQL過程已成功完成。 其中,F(xiàn)K_SB_HJJL_RELATION__SB_PZXH為出現(xiàn)錯誤的外鍵名稱。 附存儲過程腳本:
上一頁
標簽:股票投資 聊城 通化 池州 南平 襄陽 南平 嘉峪關
上一篇:Oracle系統(tǒng)表外鍵的更名
下一篇:如何確定Oracle數(shù)據(jù)庫表重復的記錄
Copyright ? 1999-2012 誠信 合法 規(guī)范的巨人網(wǎng)絡通訊始建于2005年
蘇ICP備15040257號-8