在SQL SERVER中的使用過程中,視圖是我們不可避免要經常使用到的。那到底什麼是視圖呢?概括的講,視圖就是使用者自己寫的一段SQL語句。我們為該段SQL語句起一個名字,就稱為視圖名,以後想要利用該段SQL語句返回的結果集時,只要像查詢表一樣針對視圖名寫SQL語句就可以了,所以,你也可以把視圖想像為一個虛擬表。
下面,我們講解一個視圖的建立與使用:
一,建立視圖:
create view v_viewname as select * from table1
其中view為視圖關鍵詞,v_viewname為我們建立的視圖名,select * from table1為該視圖返回的結果集.
二,調用視圖:與查詢表一樣
select * from v_viewname
三,刪除視圖:
drop view v_viewname
從上面的操作我們可以看出,視圖建立好後,對它的操作,就和操作實體表一樣。
視圖的特點: 一,視圖著重於特定資料。 視圖可以讓使用者或者程式開發人員只看到他們所需要的資料,而不需要把表中的所有資訊與欄位暴露出來,這樣增強了資料的安全性。
二,簡化資料的操作,易維護。 我們可以將經常用到的多表聯集查詢出來的資料,或特定的結果集定義為視圖,這樣就起到了模組化資料的作用。我們在使用這些資料時直接查詢該視圖就可以,而不用到處寫長長的SQL語句,這樣也起到易維護的作用。
三,視圖可以限定查詢資料。 比如:對於不同的使用者,我們只提供部分資料給他。這樣,我們就可以在視圖中限定結果集,然後返回該視圖給他。這樣,無論使用者怎麼對視圖定義查詢條件,他也不能查詢出我們不想提供給他的資料。
視圖的最佳化: 雖然視圖可以給我們帶來種種便利,但不意味著我們就可以濫用它。因為視圖其實就是一段SQL語句,所以它的結果都是每次調用時動態產生的。如果不合理的定義視圖,必然帶來效能上的損耗。
下面是我們在建立視圖應該要注意的幾點: 一,操作視圖會比直接操作基礎資料表要慢,所以我們盡量避免在大型表上建立視圖。
二,盡量不要建立嵌套視圖,就是在視圖中使用視圖。 這樣在查詢時,會多次重複訪問基礎資料表,帶來效能損耗。
三,盡量在視圖只返回所需的資訊,盡量不要在視圖使用不需要訪問的表。
四,在大型表或者複雜定義的視圖,可以使用預存程序代替。
五,頻繁使用的視圖,可以使用索引檢視表來代替。