【檢視】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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 使用OWASP Dependency-Check對應用做個安檢
- 11 UML中的邏輯檢視、程序檢視、實現檢視、部署檢視
- onclick="return check()" 和 onclick="check()" 區別
- [Django REST framework - 檢視元件之檢視基類、檢視擴充套件類、檢視子類、檢視集]DjangoRESTFramework元件套件
- option新增空白
- 如何實現SAP GUI的自定義語法檢查(Syntax check)GUI
- check_postgres指令碼集檢查資料庫健康情況指令碼資料庫
- ASP.NET Core 5.0 MVC中的檢視分類——佈局檢視、啟動檢視、具體檢視、分部檢視ASP.NETMVC
- jquery獲得option的值和對option進行操作jQuery
- Check if String is HappyAPP
- Rust 程式設計視訊教程對應講解內容-OptionRust程式設計
- The option-critic architecture
- drf : 通用檢視類和(GenericAPIView)5個檢視擴充套件類,九個檢視子類,檢視集。APIView套件
- MYSQL 檢視MySql
- 檢視助手
- 物化檢視
- 09檢視
- 檢視層
- gc 檢視GC
- SAP WM中階儲存型別的容量檢查– Check According to Maximum Weight型別
- Oracle普通檢視和物化檢視的區別Oracle
- Django檢視之檢視類和中介軟體Django
- day04-檢視和檢視解析器
- Jquery 動態增加option及獲取值 遍歷option相關方法jQuery
- 蘋果電腦上神奇的Option鍵,巧用option鍵提升效率蘋果
- CHECK_INTERFACE作用
- check_document_position
- Kotlin Type? vs Scala OptionKotlin
- SAP WM中階Storage Type的Capacity Check – Usage check based on SUT
- Linux基楚操作指引【檢視版本、檢視路徑、檢視內容、編輯檔案】Linux
- django 的類檢視和函式檢視-雜談Django函式
- Django - 檢視層 - 檢視函式及快捷方式Django函式
- odoo檢視入門學習- tree檢視的使用Odoo
- Python版本檢視Python
- 組合檢視
- kafka檢視topicKafka
- MySQL View 檢視MySqlView
- 檢視過濾
- 檢視錶大小