【檢視】with check option

散葉涔發表於2012-04-25

我們來看下面的例子:
create or replace view testview
as
select empno,ename from emp where ename like ‘M%’
with check option;

這裡我們建立了一個檢視,並使用了with check option來限制了檢視。 然後我們來看一下檢視包含的結果:
select * from testview得到:
EMPNO ENAME
———- ———–
7654 MARTIN
7934 MILLER
這兩條記錄

然後我們在試圖將其中一條更新:
update testview
set ename = ‘Mike’
where empno = 7654;
OK,這條更新語句可以執行,並沒有什麼問題,但是當我們執行另一條更新時:
update testview
set ename = ‘Robin’
where empno = ‘7654′;
就會出現ORA-01402: 檢視 WITH CHECK OPTIDN 違反 where 子句的錯誤,這是因為什麼呢?

這是因為前面我們在建立檢視時指定了witch check option關鍵字,這也就是說,更新後的每一條資料仍然要滿足建立檢視時指定的where條件,所以我們這裡發生了錯誤ORA-01402。

但是需要說明的時 ,雖然指定了with check option,我們還是可以刪除檢視中的資料。例如上例中,我們可以使用
delete from test where where empno = 7654


--------------------------------------------------------------------------------

我建立一個檢視:
create view IS_student
as
select sno,sname,sage
from student
where sdept='IS'
with check option;
加上了with check option;後,不能執行插入操作:

insert into is_student
values('95100','李娜',12)

什麼原因?不加上with check option則可以!

with check option可以這麼解釋:透過檢視進行的修改,必須也能透過該檢視看到修改後的結果。比如你insert,那麼加的這條記錄在重新整理檢視後必須可以看到;如果修改,修改完的結果也必須能透過該檢視看到;如果刪除,當然只能刪除檢視裡有顯示的記錄。

---&gt而你只是查詢出sdept='is'的紀錄,你插入的根本不符合sdept='is'呀,所以就不行

預設情況下,由於行透過檢視進行新增或更新,當其不再符合定義檢視的查詢的條件時,它們即從檢視範圍中消失。例如,可建立一個查詢,從而定義一個檢視以在表中檢索所有員工薪水低於 $30,000 的行。如果該員工的薪水漲到了 $32,000,則查詢檢視時該特定員工將不再出現,因其薪水不符合檢視所設的標準。但是,WITH CHECK OPTION 子句強制所有資料修改語句均根據檢視執行,以符合定義檢視的 SELECT 語句中所設的條件。如果使用該子句,修改行時需考慮到不讓它在修改完後從檢視中消失。任何可能導致行消失的修改都會被取消,並顯示錯誤資訊。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26892340/viewspace-722190/,如需轉載,請註明出處,否則將追究法律責任。

相關文章