版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、第11章 視圖視圖是Oracle提供的一種查詢機制。該機制不僅可以簡化各種查詢,還可以維護(hù)數(shù)據(jù)庫信息的平安。視圖在數(shù)據(jù)庫中可以了解為一張?zhí)摂M的表,運用視圖可以補充表構(gòu)造在某些需求方面的缺乏,可以讓開發(fā)人員更方便地查詢復(fù)雜數(shù)據(jù)。本章將主要引見視圖的概念、作用以及如何創(chuàng)建、查詢、管理視圖。.11.1 Oracle視圖初學(xué)者聽到視圖會比較陌生,實踐上視圖的創(chuàng)建和操作比較簡單。在直觀印象中它和表類似,但是它不具備表的某些功能。視圖的運用和管理在許多方面和表類似,通俗來說我們普通把視圖看作沒有數(shù)據(jù)的表,本節(jié)就將引見視圖的概念和作用。.11.1.1 視圖的概念視圖是由select查詢語句定義的、基于一個或
2、多個表或視圖的一個邏輯表。視圖本身不包含任何數(shù)據(jù),也就是說視圖只是一個查詢語句的結(jié)果。它的數(shù)據(jù)最終是表中獲取的,這些表我們可以稱為基表,所以不需求在表空間中為視圖分配存儲空間。了解如下圖。.11.1.2 視圖的作用有讀者能夠會產(chǎn)生疑問,既然視圖和表類似,為什么還要學(xué)習(xí)它,其實除了select語句之外,視圖在insert、update和delete語句方面受限制,視圖的作用如下:1使數(shù)據(jù)簡化。2使數(shù)據(jù)更加獨立。3添加平安性。.11.1.3 視圖的分類在Oracle數(shù)據(jù)庫中,視圖可以被分成這樣幾種類型,關(guān)系視圖、內(nèi)嵌視圖、對象視圖和物理化視圖。在本書中,將學(xué)習(xí)關(guān)系視圖和內(nèi)嵌視圖。關(guān)系視圖就是一個續(xù)
3、表,它可以定義對數(shù)據(jù)的查詢,允許其他查詢反復(fù)運用該對象。關(guān)系視圖屬于簡單視圖,在數(shù)據(jù)庫字典中可以查看它的信息。內(nèi)嵌視圖那么是子查詢的一種,它適宜不重用的對數(shù)據(jù)的查詢,其他查詢無法運用該視圖,這種視圖不需求create命令完成,所以在數(shù)據(jù)庫字典中無法查看該視圖的信息。.11.2 關(guān)系視圖創(chuàng)建和運用可以直接運用SQL語句創(chuàng)建一個視圖,也可以運用工具SQL Developer、OEM來創(chuàng)建視圖。在創(chuàng)建視圖時,只是將視圖的定義信息保管到數(shù)據(jù)字典中,在視圖中并不保管任何數(shù)據(jù),經(jīng)過視圖而操作的數(shù)據(jù)依然保管在表中,所以不需求在表空間中為視圖分配存儲空間。.11.2.1 運用語句創(chuàng)建視圖視圖的創(chuàng)建比較簡單,有
4、一定的語法構(gòu)造,其語法構(gòu)造如下圖。.11.2.1 運用語句創(chuàng)建視圖在創(chuàng)建視圖之前,為了確保視圖的正確性,應(yīng)先測試select子查詢的語句,所以創(chuàng)建視圖的正確步驟是:1編寫select子查詢語句。2測試select子查詢語句。3檢查查詢結(jié)果的正確性。4運用該select子查詢語句創(chuàng)建視圖。創(chuàng)建視圖時,可以創(chuàng)建單表視圖,也可以創(chuàng)建多表視圖以及視圖的視圖、無源表視圖。下面將詳細(xì)講解。.11.2.1 運用語句創(chuàng)建視圖1.創(chuàng)建單表視圖單表視圖表示創(chuàng)建視圖時,是根據(jù)一個表來創(chuàng)建。在創(chuàng)建視圖之前先列出表的信息,方便和視圖作對比?!纠?1-1】創(chuàng)建視圖,這個視圖的作用是顯示city是Lansing的顧客cu
5、stomer_id、cust_first_name、cust_last_name、city、phone_number?!纠?1-2】如今我們來查詢這個視圖,查詢視圖的語法和查詢表一樣。.11.2.1 運用語句創(chuàng)建視圖2.創(chuàng)建多表視圖在通常情況下,視圖不會只根據(jù)一個表來創(chuàng)建,它會有兩個或多個源表。下面我們來引見基于兩個表的視圖,創(chuàng)建多表視圖的語法如下圖。.11.2.1 運用語句創(chuàng)建視圖【例如11-3】創(chuàng)建一個基于兩個表的視圖,把orders表和customersnew表關(guān)聯(lián)起來查詢,查詢其中order_id,、order_date、customer_id,、cust_first_name等信息
6、?!纠?1-4】如今我們來查詢這個視圖,查詢視圖的語法和查詢表一樣。.11.2.1 運用語句創(chuàng)建視圖3.創(chuàng)建視圖的視圖視圖不僅可以建立在單表或多表上,也可以用其他的視圖作為源表創(chuàng)建新的視圖。如今我們簡單演示一下在視圖的根底上創(chuàng)建一個視圖,語法如下圖。.11.2.1 運用語句創(chuàng)建視圖【例如11-5】創(chuàng)建一個前面例如11-1的一個子視圖,其實就是去掉cust_last_name這列。【例如11-6】如今我們來查詢這個視圖,查詢視圖的語法和查詢表一樣。.11.2.1 運用語句創(chuàng)建視圖4.創(chuàng)建無源表視圖在Oracle數(shù)據(jù)庫中,我們可以在沒有源表時,創(chuàng)建視圖。但是這種情況下,視圖雖然是創(chuàng)建了,但是還不
7、能運用。等到它的源表創(chuàng)建完成之后,就可以正常運用了。這種創(chuàng)建視圖的方式成為強迫創(chuàng)建視圖。可以運用force選項來強迫創(chuàng)建視圖。其語法構(gòu)造如下圖。.11.2.1 運用語句創(chuàng)建視圖【例如11-7】強迫創(chuàng)建視圖vw_table,假設(shè)該視圖的源表稱號為tableview?!纠?1-8】如今我們來查詢這個視圖,查詢視圖的語法和查詢表一樣。.11.2.1 運用語句創(chuàng)建視圖5.設(shè)置視圖只讀read only通常簡單的視圖是允許進(jìn)展DML操作的,但是這樣容易出現(xiàn)邏輯問題,由于視圖添加或更新數(shù)據(jù)實踐上是在操作視圖的源表。所以在創(chuàng)建視圖時為了防止用戶修正數(shù)據(jù),可以把視圖設(shè)成為只讀屬性,其操作比較簡單,語法如下圖
8、。.11.2.1 運用語句創(chuàng)建視圖【例如11-9】創(chuàng)建視圖,這個視圖的作用是顯示city是Lansing的顧客customer_id、cust_first_name、cust_last_name、city、phone_number,并且要覆蓋前面原有的視圖,設(shè)置此視圖為只讀屬性效果?!纠?1-10】對只讀視圖vw_cus進(jìn)展查詢、添加數(shù)據(jù)、插入等DML操作進(jìn)展測試。.11.2.1 運用語句創(chuàng)建視圖6. 設(shè)置視圖約束check optioncheck option 選項表示視圖啟動了和子查詢條件一樣的約束。也就是說,假設(shè)對視圖修正或插入的數(shù)據(jù)和查詢條件不一致,那么該操作會被終止。關(guān)于檢查約束前
9、面曾經(jīng)講過,同樣可以為視圖設(shè)置檢查約束,語法如下圖。.11.2.1 運用語句創(chuàng)建視圖【例如11-11】創(chuàng)建視圖,這個視圖的作用是顯示city是Lansing的顧客customer_id、cust_first_name、cust_last_name、city、phone_number,并且為此視圖設(shè)置檢查約束?!纠?1-12】經(jīng)過Oracle中的數(shù)據(jù)字典user_constraints,查詢運用with check option所創(chuàng)建的約束。.11.2.2 運用SQL Developer創(chuàng)建視圖對于記不住視圖語法者,運用SQL Developer工具創(chuàng)建視圖方便簡約,下面我們就為大家演示一下如
10、何運用該工具來創(chuàng)建視圖?!纠?1-13】運用SQL Developer工具創(chuàng)建一個基于兩個表的視圖,把orders表和employees表關(guān)聯(lián)起來查詢,查詢其中order_id、order_date、sales_rep_id、first_name。.11.2.3 運用OEM創(chuàng)建視圖除了上述兩種方法外,在OEM中,可以經(jīng)過界面交互的方式創(chuàng)建視圖?!纠?1-14】結(jié)合數(shù)據(jù)表customersnew,創(chuàng)建視圖,這個視圖的作用是顯示city是Lansing的顧客customer_id、cust_first_name信息。.11.2.4 查看及操作訪問視圖視圖創(chuàng)建之后,可以查看視圖,也可以運用操作訪
11、問視圖。1.查看視圖定義視圖創(chuàng)建之后,其定義存在于數(shù)據(jù)庫中??梢越?jīng)過SQL Developer的Views窗口來查看視圖VW_E在數(shù)據(jù)庫中的信息?!纠?1-15】查看例如11-11創(chuàng)建的視圖vw_cus?!纠?1-16】經(jīng)過數(shù)據(jù)字典user_view查詢當(dāng)前用戶擁有的一切視圖信息。以查看vw_cus為例。.11.2.4 查看及操作訪問視圖2.查看關(guān)系視圖功能我們知道視圖創(chuàng)建之后,可以查詢視圖中的數(shù)據(jù)。除此之外,我們也可以像表一樣完成數(shù)據(jù)支配的功能。即利用視圖,可以插入數(shù)據(jù)和更新數(shù)據(jù),也可以刪除其中數(shù)據(jù)。對視圖的操作僅限于更新、插入、刪除。【例如11-17】Oracle內(nèi)置視圖user_up
12、datable_columns定義了用戶視圖中各列的可更新情況。.11.2.4 查看及操作訪問視圖3.操作訪問視圖對視圖進(jìn)展插入、更新操作。需求留意的是。只讀視圖僅可以進(jìn)展查詢操作,而無法進(jìn)展更新及插入數(shù)據(jù)的操作。對于創(chuàng)建了約束的視圖,運用視圖時會檢查涉及的數(shù)據(jù)能否能經(jīng)過select子查詢的where條件,否那么SQL語句天性勝利執(zhí)行。.11.2.4 查看及操作訪問視圖1更新視圖數(shù)據(jù)更新視圖數(shù)據(jù),實踐是更新根底表中的數(shù)據(jù)。我們可以利用update語句來更新視圖中的數(shù)據(jù),但是視圖本身并不存儲數(shù)據(jù)。更新視圖中的數(shù)據(jù)時,需求滿足對應(yīng)基表的相關(guān)約束。【例如11-18】在視圖vw_cus,該視圖設(shè)置了w
13、ith check option選項,要求city是Lansing,現(xiàn)欲將customer_id為982員工姓名調(diào)整為“Alva,可以更新視圖?!纠?1-19】經(jīng)過更新視圖vw_cus,將customer_id為員工姓名調(diào)整為“Alva。【例如11-20】查詢根底表customersnew中的數(shù)據(jù)進(jìn)展驗證。.11.2.4 查看及操作訪問視圖2向視圖插入數(shù)據(jù)利用insert語句,向視圖中插入數(shù)據(jù)。運用視圖進(jìn)展插入時,插入的數(shù)據(jù)也同樣需求滿足基表和視圖的相關(guān)約束?!纠?1-21】在視圖vw_cus中,插入新員工983的相關(guān)信息,但是沒有為city賦值,所以會遇到錯誤。【例如11-22】在視圖v
14、w_cus中,重新嘗試插入新顧客983的相關(guān)信息,此次為city賦值。【例如11-23】在向視圖vw_cus中插入數(shù)據(jù)之后,重新查詢視圖中的數(shù)據(jù)。.11.2.4 查看及操作訪問視圖3用視圖進(jìn)展刪除。【例如11-24】利用視圖vw_cus,刪除編號為983的顧客相關(guān)信息。【例如11-25】視圖vw_cus刪除數(shù)據(jù)之后,重新查詢視圖中的數(shù)據(jù)。.11.2.5 運用SQL Developer工具訪問視圖運用SQL Developer對視圖數(shù)據(jù)操作也很直觀、簡單,相對而言運用起來容易上手。在本小節(jié)為大家演示一下在SQL Developer下對視圖數(shù)據(jù)的更新、插入、刪除等。1.更新數(shù)據(jù)【例如11-26】運
15、用SQL Developer工具在將視圖w_cus中,把視圖中顧客編號為316的city改為北京?!纠?1-27】運用SQL Developer工具在將視圖w_cus中,把視圖中顧客編號為316的cust_first_name改為Sissy?!纠?1-28】我們之前創(chuàng)建了視圖w_orders_cus,該視圖的源表是orders、customersnew,運用該視圖更新數(shù)據(jù),將顧客編號為316的cust_first_name改為Angel。.11.2.5 運用SQL Developer工具訪問視圖2.視圖數(shù)據(jù)的插入有時候我們也可以為視圖添加數(shù)據(jù),為了操作簡單,就以SQL Developer工
16、具為例為大家簡單演示一下視圖添加數(shù)據(jù)的操作。和前面講的修正數(shù)據(jù)一樣,翻開對應(yīng)視圖即可對其操作?!纠?1-29】運用SQL Developer工具在為視圖w_cus添加數(shù)據(jù),顧客編號為983的,city必需賦值為Lansing。從圖中,看出數(shù)據(jù)勝利插入。.11.2.5 運用SQL Developer工具訪問視圖3.視圖數(shù)據(jù)的刪除視圖中刪除數(shù)據(jù)時,直接選中對應(yīng)行,單擊“X按鈕,即可完成刪除視圖數(shù)據(jù),由于其操作很簡單,這里我們就不引見了。對于多表銜接視圖,刪除操作也是不允許的。.11.3 內(nèi)嵌視圖的創(chuàng)建和運用內(nèi)嵌視圖不需求視圖名,只是一段SQL語句,通常在子查詢中作為一個中間數(shù)據(jù)集,它可以在添加、
17、刪除、修正操作中運用。內(nèi)嵌視圖無須創(chuàng)建真正的數(shù)據(jù)庫對象,而只是封裝查詢,因此會節(jié)約數(shù)據(jù)庫資源。.11.3 內(nèi)嵌視圖的創(chuàng)建和運用【例如11-30】在表orders中存儲了顧客的訂單信息,現(xiàn)欲獲取order_total最多的前三個訂單的信息。結(jié)合利用rownum3的條件可以前往前三行行記錄。【例如11-31】在例如11-14中,運用了內(nèi)嵌視圖獲得了訂單最多的三個記錄。同時,還想獲得這些訂單對應(yīng)的顧客的聯(lián)絡(luò)方式,那么可以運用內(nèi)嵌視圖與表customersnew進(jìn)展銜接。此時,在內(nèi)嵌視圖與表customersnew中會存在反復(fù)列,因此,需求為內(nèi)嵌視圖指定別名。.11.4 視圖的修正視圖的修正比較特殊,
18、不能像表一樣修正,更準(zhǔn)確的說他沒有修正選項,我們采用覆蓋原有視圖的方法來修正視圖,但這并不會影響視圖的運用。由于視圖本身不包含數(shù)據(jù),所以覆蓋原有視圖時就不存在數(shù)據(jù)喪失的問題。本小節(jié)將主要引見運用SQL Developer視圖構(gòu)造和視圖數(shù)據(jù)的修正等操作。.11.4.1 運用語句修正視圖假設(shè)發(fā)現(xiàn)視圖的定義不適宜,可以對其進(jìn)展修正。實踐上視圖中的select語句是不能直接修正的,所以修正視圖的一種方法是先刪除視圖,再重新創(chuàng)建。另一種方法是在創(chuàng)建視圖的create語句中運用or replace選項。帶or replace選項的create語句語法構(gòu)造如下圖。.11.4.2 運用SQL Developer工具修正視圖下面我們用SQL Developer演示一下修正視圖的構(gòu)造?!纠?1-32】運用SQL Developer工具修正視圖vw_cus,將視圖中customer_id字段取別名為id。.11.4.3 運用OEM修正視圖除了運用語句和SQL Developer工具更改視圖外,也可以運用OEM修正視圖?!纠?1-33】運用OEM修正視圖vw_cus。.11.5 視圖的刪除視圖的刪除和表刪除操作方式一樣,可以運用S
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 會計專業(yè)大一學(xué)期計劃范文
- 鄉(xiāng)鎮(zhèn)文化站建成文藝晚會主持詞
- 七夕節(jié)促銷活動方案
- 范文新學(xué)期學(xué)習(xí)計劃范文集錦十篇
- 個人工作總結(jié)(集錦14篇)
- 高等數(shù)學(xué)教程 上冊 第4版 測試題 高數(shù)1-測試二
- 荒山租地合同協(xié)議書(2篇)
- 分段計費說課稿
- 南京工業(yè)大學(xué)浦江學(xué)院《汽車電氣設(shè)備》2023-2024學(xué)年第一學(xué)期期末試卷
- 南京工業(yè)大學(xué)浦江學(xué)院《計算機設(shè)計》2022-2023學(xué)年期末試卷
- 介紹方志敏(修訂版)
- 信息技術(shù)教師專業(yè)發(fā)展
- 公職人員廉潔自律課件
- 建筑工程精細(xì)化管理培訓(xùn)講解
- 學(xué)校領(lǐng)導(dǎo)測驗題目和答案(經(jīng)過打?。?/a>
- 風(fēng)景園林專業(yè)職業(yè)生涯規(guī)劃
- 食品安全員崗位的主要職責(zé)范本
- 《構(gòu)成基礎(chǔ)》課程習(xí)題及答案
- 中層干部考核測評表
- 《“要拿我當(dāng)一挺機關(guān)槍使用”-紀(jì)念白求恩同志》
- 精美工業(yè)快速門施工方案
評論
0/150
提交評論