視圖 對(duì)于數(shù)據(jù)庫(kù)來說 是一個(gè)最基本的 也是最重要的功能之一 數(shù)據(jù)庫(kù)視圖設(shè)計(jì)的好壞 直接跟數(shù)據(jù)庫(kù)的性能相關(guān) 而且 在大型數(shù)據(jù)庫(kù)設(shè)計(jì)中 大家分工合作 基礎(chǔ)表的設(shè)計(jì)與報(bào)表視圖的設(shè)計(jì)往往由不同的人負(fù)責(zé) 所以 視圖的設(shè)計(jì)管理跟基礎(chǔ)表的設(shè)計(jì)管理一樣 都有很大的學(xué)問 在這篇文章中 筆者將結(jié)合自己在視圖設(shè)計(jì)管理方面的工作經(jīng)驗(yàn) 談?wù)勗谶@方面的一些鮮為人知的技巧
創(chuàng)新互聯(lián)是一家專業(yè)提供豐林企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、H5響應(yīng)式網(wǎng)站、小程序制作等業(yè)務(wù)。10年已為豐林眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。
技巧一 把基礎(chǔ)表與視圖脫離開來
一般來說 視圖都是在基礎(chǔ)表的上面建立起來的 也就是說 要先有基礎(chǔ)表 而后有視圖 但是 在大型數(shù)據(jù)庫(kù)的設(shè)計(jì)過程中 出于項(xiàng)目時(shí)間的考慮 往往基礎(chǔ)表與視圖的設(shè)計(jì)是同時(shí)進(jìn)行的 如一些人負(fù)責(zé)基礎(chǔ)表的建立 另一些人則負(fù)責(zé)視圖的設(shè)計(jì)與建立等等 在這個(gè)過程中 往往基礎(chǔ)表不存在的時(shí)候 就需要建立一些視圖 以加快項(xiàng)目的進(jìn)度
為了使得基礎(chǔ)表的創(chuàng)建和修改與視圖的創(chuàng)建于修改沒有必然的聯(lián)系 以便于員工之間工作的同步 提高工作效率 所以 在Oracle數(shù)據(jù)庫(kù)中提出了一個(gè) 強(qiáng)制創(chuàng)建視圖 的概念 也就是說 正常情況下 如果基本表不存在 則創(chuàng)建視圖就會(huì)失敗 但是 我們可以在創(chuàng)建視圖的過程中 加入一個(gè)參數(shù) 只要?jiǎng)?chuàng)建視圖的語(yǔ)法沒有錯(cuò)誤的話 即使基礎(chǔ)表不存在 仍然可以建立這張表格 這個(gè)有用的參數(shù)就是force選項(xiàng) 如我們建立視圖時(shí) CREATE FORCE VIEW TEXT 只需要在關(guān)鍵字VIEW之前加入FORCE參數(shù)即可 如此的話 系統(tǒng)在編譯視圖的時(shí)候 就不會(huì)去考慮基礎(chǔ)表是否存在
不過這里要注意一點(diǎn) 若基礎(chǔ)表不存在的話 則編譯后該視圖的狀態(tài)為 無(wú)效 不能再這個(gè)視圖的基礎(chǔ)上執(zhí)行一些操作 如查詢操作等等 當(dāng)下次訪問這個(gè)視圖的時(shí)候 則數(shù)據(jù)庫(kù)會(huì)對(duì)這個(gè)視圖進(jìn)行重新編譯 若此時(shí)基礎(chǔ)表存在了 則該基礎(chǔ)表就會(huì)變?yōu)橛行?若基礎(chǔ)表不存在 則這視圖就會(huì)失效
Oracle數(shù)據(jù)庫(kù)之所以如此設(shè)置 主要是出于在數(shù)據(jù)庫(kù)設(shè)計(jì)過程中協(xié)同辦公的需要 有了這個(gè)功能之后 則在數(shù)據(jù)庫(kù)建立的過程中 只要把數(shù)據(jù)庫(kù)基礎(chǔ)表與視圖設(shè)計(jì)好之后 大家就可以分工合作 在數(shù)據(jù)庫(kù)中建立相關(guān)的對(duì)象 不然的話 要等基礎(chǔ)表建立好之后再建立視圖 如此就會(huì)明顯的影響數(shù)據(jù)庫(kù)建立的進(jìn)度 所以 在數(shù)據(jù)庫(kù)建立的過程中 特別是中大型的數(shù)據(jù)庫(kù)系統(tǒng) 這是一個(gè)很實(shí)用的功能
技巧二 創(chuàng)建視圖的理想步驟
無(wú)論是簡(jiǎn)單視圖 還是比較復(fù)雜的視圖 筆者覺得數(shù)據(jù)庫(kù)管理員在創(chuàng)建視圖的時(shí)候 最好能夠遵循一定的步驟 這一方面是因?yàn)橐晥D的更改相對(duì)來說 是一件比較麻煩的工作 所以 我們?cè)诮⒁晥D的時(shí)候 要確保視圖的準(zhǔn)確性 另一方面 視圖是基礎(chǔ)表的一個(gè)體現(xiàn)形式 若不按步驟來做的話 有可能就不能夠達(dá)到我們預(yù)計(jì)的需求
當(dāng)然這個(gè)步驟沒有官方的版本 完全是數(shù)據(jù)庫(kù)管理員根據(jù)實(shí)際的經(jīng)驗(yàn)總結(jié)出來的 這個(gè)步驟不僅對(duì)Oracle數(shù)據(jù)庫(kù)有效 對(duì)于其他數(shù)據(jù)庫(kù)來說 也是類似的道理
一般來說 視圖創(chuàng)建可以分為五步走
第一步 先考慮Select語(yǔ)句的編寫 我們知道 視圖其實(shí)就是一個(gè)Select語(yǔ)句的集合 所以 我們建立視圖的第一步 就是考慮這個(gè)Select語(yǔ)句該如何編寫 這個(gè)Select語(yǔ)句編寫的是否合理 執(zhí)行效率的高低直接影響著這個(gè)視圖的性能 另外 在Select語(yǔ)句中 可能還會(huì)有格式的控制 內(nèi)容的編排等等 如在Select語(yǔ)句中 可以把一些字段合并成一個(gè)字段;也可以把相關(guān)的內(nèi)容進(jìn)行倒置等等 這些功能都是Select語(yǔ)句完成的 所以可以這么說 Select語(yǔ)句的編寫是視圖建立的基礎(chǔ)
第二步 對(duì)這個(gè)Select語(yǔ)句進(jìn)行測(cè)試 當(dāng)我們編寫好Select語(yǔ)句之后 就需要在數(shù)據(jù)庫(kù)中執(zhí)行這條語(yǔ)句 看其能否查詢到我們想要的值 在對(duì)Select語(yǔ)句進(jìn)行測(cè)試的時(shí)候 需要注意一個(gè)問題 有時(shí)候Select查詢語(yǔ)句可以查到準(zhǔn)確的數(shù)據(jù) 但是在以這條語(yǔ)句建立視圖的時(shí)候 可能就會(huì)通不過 如在一些表之間的連接查詢的時(shí)候 如果兩個(gè)表中有個(gè)字段名相同 是可以的 因?yàn)樗麄兂俗侄蚊种?還有表名一起來定義這個(gè)字段 如A name與B name 這是不算重名的 但是 若在建立視圖的時(shí)候 這就會(huì)被認(rèn)為是重復(fù)的列明 需要對(duì)其中的一個(gè)列名進(jìn)行重定義 這一點(diǎn)在數(shù)據(jù)庫(kù)視圖建立的時(shí)候 要特別的注意
第三步 考慮查詢結(jié)果的準(zhǔn)確性 通過查詢語(yǔ)句把我們想要的結(jié)果查詢出來后 我們就需要看看這個(gè)結(jié)果是否滿足我們的需要 在這個(gè)過程中 我們主要注意兩點(diǎn) 一是形式字段是否齊全 在一些應(yīng)用系統(tǒng)中 若數(shù)據(jù)庫(kù)的視圖要能夠被前臺(tái)的應(yīng)用程序調(diào)用的話 則必須包含一些形式字段 如筆者以前在設(shè)計(jì)一個(gè)ERP系統(tǒng)的時(shí)候 若前臺(tái)系統(tǒng)要調(diào)用數(shù)據(jù)庫(kù)中的視圖的時(shí)候 必須包含記錄更新時(shí)間 更新者 記錄創(chuàng)建時(shí)間 創(chuàng)建者等相關(guān)信息 若缺乏這些信息的話 則前臺(tái)調(diào)用這張視圖的時(shí)候 就會(huì)出現(xiàn)錯(cuò)誤 故在考慮查詢結(jié)果準(zhǔn)確性的問題的時(shí)候 就要考慮到前臺(tái)應(yīng)用程序的需要 看看這些形式字段是否齊全 二是實(shí)體內(nèi)容的完整性 我們到底需要顯示表中的哪些字段呢 這個(gè)我們?cè)谶@里要確認(rèn)清楚 若顯示內(nèi)容太多的話 則會(huì)影響視圖的執(zhí)行效率 而且也會(huì)降低視圖的安全性作用;但是 若字段內(nèi)容顯示不足的話 則以后要添加字段的話 會(huì)比較麻煩 有一定的工作量 所以在這個(gè)檢驗(yàn)的時(shí)候 需要根據(jù)視圖的實(shí)際功用 確定視圖需要顯示的內(nèi)容
第四步 視圖的修飾 有時(shí)候 為了閱讀的方便 我們需要對(duì)查詢結(jié)果進(jìn)行一些修飾 如現(xiàn)在有兩張表 一張是員工基本信息表 這表中有員工姓名 員工職位編號(hào)等等;另一張表是職位基本信息表 在這表中有職位編號(hào) 職位名稱 我們希望在視圖中能夠如下顯示 職位 員工名字 如數(shù)據(jù)庫(kù)工程師 Victor 也就是說 把兩個(gè)字段合并起來 并且在中間加入一個(gè)冒號(hào) 這些格式性的內(nèi)容都是在查詢的時(shí)候?qū)崿F(xiàn)的 所以 我們確認(rèn)查詢的結(jié)果沒有錯(cuò)誤之后 接下來就要確認(rèn)格式問題 若能夠在視圖中規(guī)范這些格式問題 則前臺(tái)的程序設(shè)計(jì)就會(huì)相對(duì)來說比較簡(jiǎn)單
lishixinzhi/Article/program/Oracle/201311/17034
Oracle創(chuàng)建跨用戶視圖,也就是跨模式視圖。
1、首先在A中運(yùn)行,把讀取的權(quán)限賦值給B,這樣在B中建立視圖就可
grant select on A.userA to B; 以讀取A中userA表中的數(shù)據(jù)了。
2、登錄用戶B表空間,建立視圖 語(yǔ)句如下:
create or
replace view cas_user_view as select
B.LOGIN_NAME,B.PASSWORD,B.LOGIN_FLAG from userB B union select
A.LOGIN_NAME,A.PASSWORD,A.LOGIN_FLAG
from A.userA
A;
到此,在用戶B中已建立名為
cas_user_view的視圖,可以供A和B同時(shí)使用。
基于表或其他視圖來創(chuàng)建視圖,目的將一些復(fù)雜的查詢簡(jiǎn)化,提高查詢速度 。如:
CREATE VIEW v_name AS SELECT b.dname,a.ename FROM emp a,dept b
WHERE a.deptno=b.deptno ;
查詢部門名和員工名 通過建立視圖,v_name 視圖就等同于SELECT b.dname,a.ename FROM emp a,dept b
WHERE a.deptno=b.deptno 這樣可以大大的簡(jiǎn)化程序
1
create?view?V_StudInfo
as
select?a.學(xué)號(hào),a.姓名,b.課程號(hào),b.課程名,
case?when?c.成績(jī)?between?90?and?100?then?'優(yōu)'
when?c.成績(jī)?between?80?and?89?then?'良'
when?c.成績(jī)?between?70?and?79?then?'中'
when?c.成績(jī)?between?60?and?69?then?'及格'
else?'不及格'?end?成績(jī)等級(jí)
from?學(xué)生表?a,課程表?b,?成績(jī)表?c?where?a.學(xué)號(hào)=c.學(xué)號(hào)
and?b.課程號(hào)=c.課程號(hào)
2
create?view?V_Stud
as
select?a.學(xué)號(hào),a.姓名,count(*)?所修科目數(shù),avg(成績(jī))?平均成績(jī)
from?學(xué)生表?a,課程表?b,?成績(jī)表?c?where?a.學(xué)號(hào)=c.學(xué)號(hào)
and?b.課程號(hào)=c.課程號(hào)
and?a.學(xué)號(hào)?in
(select?a.學(xué)號(hào)
from?學(xué)生表?a,課程表?b,?成績(jī)表?c?where?a.學(xué)號(hào)=c.學(xué)號(hào)
and?b.課程號(hào)=c.課程號(hào)?and?b.課程名='英語(yǔ)'?and?c.成績(jī)75)
表名和字段名,自己跟你實(shí)際的核對(duì)一下,不同的改一下
CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name
[(alias[, alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY]
OR REPLACE :若所創(chuàng)建的試圖已經(jīng)存在,ORACLE自動(dòng)重建該視圖;
FORCE :不管基表是否存在ORACLE都會(huì)自動(dòng)創(chuàng)建該視圖;
NOFORCE :只有基表都存在ORACLE才會(huì)創(chuàng)建該視圖:
alias :為視圖產(chǎn)生的列定義的別名;
subquery :一條完整的SELECT語(yǔ)句,可以在該語(yǔ)句中定義別名;
WITH CHECK OPTION :插入或修改的數(shù)據(jù)行必須滿足視圖定義的約束;
WITH READ ONLY :該視圖上不能進(jìn)行任何DML操作。
CREATE OR REPLACE VIEW dept_sum_vw
(name,minsal,maxsal,avgsal)
AS
SELECT d.dname,min(e.sal),max(e.sal),avg(e.sal)
FROM emp e,dept d
WHERE e.deptno=d.deptno
GROUP BY d.dname;
--給用戶授權(quán)創(chuàng)建視圖
-- grant create all view to zdgshr; 所有數(shù)據(jù)庫(kù)都能創(chuàng)建視圖的用戶
grant create view to zdgshr;
--創(chuàng)建簡(jiǎn)單視圖
create view temp
as
select * from zd_member_basic_info;
--測(cè)試
select * from temp where rownum=1;
--創(chuàng)建簡(jiǎn)單視圖:只讀
create or replace view temp1
as
select id,job_number,name,dept_id from zd_member_basic_info
with read only;
--測(cè)試
insert into temp1(id,job_number,name,dept_id) values(1,0,'張三',1300);
視圖的刪除:
DROP VIEW VIEW_NAME語(yǔ)句刪除視圖。
刪除視圖的定義不影響基表中的數(shù)據(jù)。
只有視圖所有者和具備DROP VIEW權(quán)限的用戶可以刪除視圖。
視圖被刪除后,基于被刪除視圖的其他視圖或應(yīng)用將無(wú)效。
四、視圖分為簡(jiǎn)單視圖和復(fù)雜視圖。
簡(jiǎn)單視圖只從單表里獲取數(shù)據(jù);復(fù)雜視圖從多表里獲取數(shù)據(jù)。
簡(jiǎn)單視圖不包含函數(shù)和數(shù)據(jù)組;復(fù)雜視圖包含函數(shù)和數(shù)據(jù)組。
簡(jiǎn)單視圖可以實(shí)現(xiàn)DML操作;復(fù)雜視圖不可以。
create or replace view temp1
as
select distinct name,job_number,dept_id from zd_member_basic_info
with read only;
delete from zd_member_basic_info where name='而過';
create or replace view temp
as
select * from zd_member_basic_info order by name;
create
or
replace
view
視圖名
as
...;
基本的創(chuàng)建命令:
比如:創(chuàng)建表book的一張視圖
create
or
replace
view_book
as
select
*
from
book
where
book_id
='001';
使用視圖,就用select
*
from
view_book;
當(dāng)然了,使用
圖形化界面
更方便。