SQL Server中視圖的特點與最佳化

來源:互聯網
上載者:User

在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語句,所以它的結果都是每次調用時動態產生的。如果不合理的定義視圖,必然帶來效能上的損耗。

下面是我們在建立視圖應該要注意的幾點: 一,操作視圖會比直接操作基礎資料表要慢,所以我們盡量避免在大型表上建立視圖。

二,盡量不要建立嵌套視圖,就是在視圖中使用視圖。 這樣在查詢時,會多次重複訪問基礎資料表,帶來效能損耗。

三,盡量在視圖只返回所需的資訊,盡量不要在視圖使用不需要訪問的表。

四,在大型表或者複雜定義的視圖,可以使用預存程序代替。

五,頻繁使用的視圖,可以使用索引檢視表來代替。

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.