【檢視】with check option
我們來看下面的例子:
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,那麼加的這條記錄在重新整理檢視後必須可以看到;如果修改,修改完的結果也必須能透過該檢視看到;如果刪除,當然只能刪除檢視裡有顯示的記錄。
--->而你只是查詢出sdept='is'的紀錄,你插入的根本不符合sdept='is'呀,所以就不行
預設情況下,由於行透過檢視進行新增或更新,當其不再符合定義檢視的查詢的條件時,它們即從檢視範圍中消失。例如,可建立一個查詢,從而定義一個檢視以在表中檢索所有員工薪水低於
$30,000 的行。如果該員工的薪水漲到了 $32,000,則查詢檢視時該特定員工將不再出現,因其薪水不符合檢視所設的標準。但是,WITH
CHECK OPTION 子句強制所有資料修改語句均根據檢視執行,以符合定義檢視的 SELECT
語句中所設的條件。如果使用該子句,修改行時需考慮到不讓它在修改完後從檢視中消失。任何可能導致行消失的修改都會被取消,並顯示錯誤資訊。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26892340/viewspace-722190/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle 建立檢視用 with check option 子句詳解Oracle
- 檢視中with check option的作用是什麼?
- 使用檢視配合With Check Option實現複雜校驗
- WITH CHECK OPTION 詳解
- Using the WITH CHECK OPTION
- create view with check optionView
- ORACLE WITH CHECK OPTION子句詳解Oracle
- insert WITH CHECK OPTION的用法
- Oracle檢視授權(with grant option)Oracle
- MySQL資料庫檢視:檢視定義、建立檢視、修改檢視MySql資料庫
- [Django REST framework - 檢視元件之檢視基類、檢視擴充套件類、檢視子類、檢視集]DjangoRESTFramework元件套件
- 使用OWASP Dependency-Check對應用做個安檢
- 檢測不再使用的索引–check-unused-keys索引
- Check_nrpe外掛之check_uptime.sh檢測系統啟動時間
- with grant option與with admin option區別
- 微信小程式-檢視檢視引用微信小程式
- ASP.NET Core 5.0 MVC中的檢視分類——佈局檢視、啟動檢視、具體檢視、分部檢視ASP.NETMVC
- 11G執行oracle自帶的檢查 checkOracle
- Oracle檢視:常用動態效能檢視Oracle
- 【檢視】oracle 資料字典檢視之 “小”檢視 CAT, TAB, SEQ, SYN ...Oracle
- oracle with * option 理解Oracle
- Jumping with Option
- 普通檢視和物化檢視的區別
- 使用index_stats檢視檢視索引效率Index索引
- drf : 通用檢視類和(GenericAPIView)5個檢視擴充套件類,九個檢視子類,檢視集。APIView套件
- MYSQL 檢視MySql
- gc 檢視GC
- SQL檢視SQL
- Mysql檢視:MySql
- onclick="return check()" 和 onclick="check()" 區別
- Rust 程式設計視訊教程對應講解內容-OptionRust程式設計
- Animator視窗檢視Project檢視PlayerIdleAnimation和PlayerWalkingAnimationProject
- Oracle普通檢視和物化檢視的區別Oracle
- day04-檢視和檢視解析器
- Django檢視之檢視類和中介軟體Django
- 物化檢視妙用__表同步使用物化檢視方法
- 經典星號檢視器檢視密碼密碼
- 【檢視】oracle 資料字典檢視之 DICT / DICTIONARYOracle