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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章