久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

優化SQL Server 索引的小技巧有哪些

152次閱讀
沒有評論

共計 2075 個字符,預計需要花費 6 分鐘才能閱讀完成。

優化 SQL Server 索引的小技巧有哪些,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面丸趣 TV 小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

在本文中,我將說明如何用 SQL Server 的工具來優化數據庫索引的使用,本文還涉及到有關索引的一般性知識。關于索引的常識

影響到數據庫性能的最大因素就是索引。由于該問題的復雜性,我只可能簡單的談談這個問題,不過關于這方面的問題,目前有好幾本不錯的書籍可供你參閱。我在這里只討論兩種 SQL Server 索引,即 clustered 索引和 nonclustered 索引。當考察建立什么類型的索引時,你應當考慮數據類型和保存這些數據的 column。同樣,你也必須考慮數據庫可能用到的查詢類型以及使用的最為頻繁的查詢類型。

索引的類型

如果 column 保存了高度相關的數據,并且常常被順序訪問時,最好使用 clustered 索引,這是因為如果使用 clustered 索引,SQL Server 會在物理上按升序(默認)或者降序重排數據列,這樣就可以迅速的找到被查詢的數據。同樣,在搜尋控制在一定范圍內的情況下,對這些 column 也最好使用 clustered 索引。這是因為由于物理上重排數據,每個表格上只有一個 clustered 索引。

與上面情況相反,如果 columns 包含的數據相關性較差,你可以使用 nonculstered 索引。你可以在一個表格中使用高達 249 個 nonclustered 索引——盡管我想象不出實際應用場合會用的上這么多索引。

當表格使用主關鍵字(primary keys),默認情況下 SQL Server 會自動對包含該關鍵字的 column(s) 建立一個獨有的 cluster 索引。很顯然,對這些 column(s) 建立獨有索引意味著主關鍵字的唯一性。當建立外關鍵字(foreign key)關系時,如果你打算頻繁使用它,那么在外關鍵字 cloumn 上建立 nonclustered 索引不失為一個好的方法。如果表格有 clustered 索引,那么它用一個鏈表來維護數據頁之間的關系。相反,如果表格沒有 clustered 索引,SQL Server 將在一個堆棧中保存數據頁。

數據頁

當索引建立起來的時候,SQLServer 就建立數據頁(datapage),數據頁是用以加速搜索的指針。當索引建立起來的時候,其對應的填充因子也即被設置。設置填充因子的目的是為了指示該索引中數據頁的百分比。隨著時間的推移,數據庫的更新會消耗掉已有的空閑空間,這就會導致頁被拆分。頁拆分的后果是降低了索引的性能,因而使用該索引的查詢會導致數據存儲的支離破碎。當建立一個索引時,該索引的填充因子即被設置好了,因此填充因子不能動態維護。為了更新數據頁中的填充因子,我們可以停止舊有索引并重建索引,并重新設置填充因子(注意:這將影響到當前數據庫的運行,在重要場合請謹慎使用)。DBCC INDEXDEFRAG 和 DBCC DBREINDEX 是清除 clustered 和 nonculstered 索引碎片的兩個命令。INDEXDEFRAG 是一種在線操作(也就是說,它不會阻塞其它表格動作,如查詢),而 DBREINDEX 則在物理上重建索引。在絕大多數情況下,重建索引可以更好的消除碎片,但是這個優點是以阻塞當前發生在該索引所在表格上其它動作為代價換取來得。當出現較大的碎片索引時,INDEXDEFRAG 會花上一段比較長的時間,這是因為該命令的運行是基于小的交互塊(transactional block)。

填充因子

當你執行上述措施中的任何一個,數據庫引擎可以更有效的返回編入索引的數據。關于填充因子(fillfactor)話題已經超出了本文的范疇,不過我還是提醒你需要注意那些打算使用填充因子建立索引的表格。

在執行查詢時,SQL Server 動態選擇使用哪個索引。為此,SQL Server 根據每個索引上分布在該關鍵字上的統計量來決定使用哪個索引。值得注意的是,經過日常的數據庫活動(如插入、刪除和更新表格),SQL Server 用到的這些統計量可能已經“過期”了,需要更新。你可以通過執行 DBCC SHOWCONTIG 來查看統計量的狀態。當你認為統計量已經“過期”時,你可以執行該表格的 UPDATE STATISTICS 命令,這樣 SQL Server 就刷新了關于該索引的信息了。

建立數據庫維護計劃

SQL Server 提供了一種簡化并自動維護數據庫的工具。這個稱之為數據庫維護計劃向導(Database Maintenance Plan Wizard,DMPW)的工具也包括了對索引的優化。如果你運行這個向導,你會看到關于數據庫中關于索引的統計量,這些統計量作為日志工作并定時更新,這樣就減輕了手工重建索引所帶來的工作量。如果你不想自動定期刷新索引統計量,你還可以在 DMPW 中選擇重新組織數據和數據頁,這將停止舊有索引并按特定的填充因子重建索引。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注丸趣 TV 行業資訊頻道,感謝您對丸趣 TV 的支持。

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-17發表,共計2075字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 独山县| 贞丰县| 河北区| 肇州县| 沙雅县| 六安市| 乌兰察布市| 定襄县| 罗源县| 林西县| 鹤壁市| 杭锦旗| 延长县| 山阴县| 宜宾县| 邹平县| 鄯善县| 宁明县| 奈曼旗| 柘城县| 宜兰县| 柘荣县| 甘德县| 广平县| 禄劝| 上饶县| 和田市| 巩留县| 土默特右旗| 富民县| 平果县| 凌云县| 苍山县| 桐柏县| 宜丰县| 青冈县| 泰兴市| 屯留县| 上思县| 成武县| 黔东|