我創建一個視圖:
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則可以!
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,那麼加的這條記錄在刷新視圖後必須可以看到;如果修改,修改完的結果也必須能通過該視圖看到;如果刪除,當然只能刪除視圖裏有顯示的記錄。
--->而你只是查詢出sdept='is'的紀錄,你插入的根本不符合sdept='is'呀,所以就不行
--->而你只是查詢出sdept='is'的紀錄,你插入的根本不符合sdept='is'呀,所以就不行
默認情況下,由於行通過視圖進行添加或更新,當其不再符合定義視圖的查詢的條件時,它們即從視圖範圍中消失。例如,可創建一個查詢,從而定義一個視圖以在表中檢索所有員工薪水低於 $30,000 的行。如果該員工的薪水漲到了 $32,000,則查詢視圖時該特定員工將不再出現,因其薪水不符合視圖所設的標準。但是,WITH CHECK OPTION 子句強制所有數據修改語句均根據視圖執行,以符合定義視圖的 SELECT 語句中所設的條件。如果使用該子句,修改行時需考慮到不讓它在修改完後從視圖中消失。任何可能導致行消失的修改都會被取消,並顯示錯誤信息 。