SQL Server索引

來源:互聯網
上載者:User

標籤:

叢集索引的順序就是資料的實體儲存體順序,因此一個表最多隻能有一個叢集索引。

非叢集索引的順序與實體儲存體順序無關。

SQL Server中的資料是按照B樹來索引,那麼叢集索引的葉結點儲存的是資料本身,而非叢集索引的葉結點,只儲存資料的引用,指標。

SQL Server以頁為單位儲存資料,一個頁佔用8k的空間,在分配空間時以8個頁,即一個盤區64k為單位。

資料庫讀取

邏輯讀取,在執行查詢時,是讀取存放在記憶體中的頁,這些頁是資料庫預先讀取到記憶體中去的。

物理讀取,在執行查詢時,SQL Server會檢查所需資料是否存在於記憶體中,如果沒有,會從硬碟讀取到記憶體中去。

預讀取,一個SQL Server處理的讀取,將一部分資料預先讀取到記憶體中,這些資料未必都是有需求的。

填滿因數

在新增資料時,如果當前頁已經滿了,會拆分出新頁,同時產生索引片段。填滿因數是在頁中填充資料的比例,預設是100%,如果在一個頁中設定填滿因數是90%,那麼在下一次新增資料的時候,頁就不會拆分了(資料不是很大),也不會產生索引片段,但是這樣會需要更多的儲存空間,也會加大B樹的深度,直接影響資料庫效率。

一般來講,填滿因數的設定是因情況而定的。

如果一個表大部分的操作都是讀取,那麼可以設定填滿因數為100%,因為很少會有拆分出新頁的時候。如果讀取和寫入的操作各佔一半,可以設定為80,90的比例。如果有大量的寫入操作,那麼就設定為50,70的比例。

當然,也可以將填滿因數設定到100%,然後經常檢查索引片段,在需要的時候重建索引。

建立索引的原則

建立索引的欄位盡量小,int的索引比text索引好很多

建立索引的欄位唯一性盡量高,不要在一億資料的表上用性別建立索引。

 

SQL最佳化

盡量避免運算式放在where的左邊

盡量避免where中出現!=和<>

盡量避免where對欄位進行null判斷

盡量避免使用遊標,可以用while迴圈代替

盡量避免返回大量的資料,可以使用分頁

不要使用select *

盡量避免使用in和not in,可以使用exists代替

 

SQL Server索引

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.