自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SQL Server數(shù)據(jù)庫中優(yōu)化索引的妙招

數(shù)據(jù)庫 SQL Server
此文章主要介紹的是在SQL Server數(shù)據(jù)庫中對索引進(jìn)行優(yōu)化的一些小妙招,以及對索引的重要性以及對索引的類型的描述。

我們今天主要向大家描述的是在SQL Server數(shù)據(jù)庫中對索引進(jìn)行優(yōu)化的一些小妙招,同時本文也有對索引的常識的描述,即,我們大家都知道影響到數(shù)據(jù)庫性能的***因素就是索引。由于該問題的復(fù)雜性,我只可能簡單的談?wù)勥@個問題。

不過關(guān)于這方面的問題,目前有好幾本不錯的書籍可供你參閱。我在這里只討論兩種SQL Server數(shù)據(jù)庫索引,即clustered索引和nonclustered索引。當(dāng)考察建立什么類型的索引時,你應(yīng)當(dāng)考慮數(shù)據(jù)類型和保存這些數(shù)據(jù)的column。同樣,你也必須考慮數(shù)據(jù)庫可能用到的查詢類型以及使用的最為頻繁的查詢類型。

 

索引的類型

 

如果column保存了高度相關(guān)的數(shù)據(jù),并且常常被順序訪問時,***使用clustered索引,這是因?yàn)槿绻褂胏lustered索引,SQL Server會在物理上按升序(默認(rèn))或者降序重排數(shù)據(jù)列,這樣就可以迅速的找到被查詢的數(shù)據(jù)。同樣,在搜尋控制在一定范圍內(nèi)的情況下,對這些column也***使用clustered索引。這是因?yàn)橛捎谖锢砩现嘏艛?shù)據(jù),每個表格上只有一個clustered索引。

 

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

 

 

當(dāng)表格使用主關(guān)鍵字(primary keys),默認(rèn)情況下SQL Server數(shù)據(jù)庫會自動對包含該關(guān)鍵字的column(s)建立一個獨(dú)有的cluster索引。很顯然,對這些column(s)建立獨(dú)有索引意味著主關(guān)鍵字的唯一性。當(dāng)建立外關(guān)鍵字(foreign key)關(guān)系時,如果你打算頻繁使用它,那么在外關(guān)鍵字cloumn上建立nonclustered索引不失為一個好的方法。

如果表格有clustered索引,那么它用一個鏈表來維護(hù)數(shù)據(jù)頁之間的關(guān)系。相反,如果表格沒有clustered索引,SQL Server數(shù)據(jù)庫將在一個堆棧中保存數(shù)據(jù)頁。

 

 

數(shù)據(jù)頁

 

當(dāng)索引建立起來的時候,SQLServer就建立數(shù)據(jù)頁(datapage),數(shù)據(jù)頁是用以加速搜索的指針。當(dāng)索引建立起來的時候,其對應(yīng)的填充因子也即被設(shè)置。設(shè)置填充因子的目的是為了指示該索引中數(shù)據(jù)頁的百分比。

隨著時間的推移,數(shù)據(jù)庫的更新會消耗掉已有的空閑空間,這就會導(dǎo)致頁被拆分。頁拆分的后果是降低了索引的性能,因而使用該索引的查詢會導(dǎo)致數(shù)據(jù)存儲的支離破碎。當(dāng)建立一個索引時,該索引的填充因子即被設(shè)置好了,因此填充因子不能動態(tài)維護(hù)。

 

為了更新數(shù)據(jù)頁中的填充因子,我們可以停止舊有索引并重建索引,并重新設(shè)置填充因子(注意:這將影響到當(dāng)前數(shù)據(jù)庫的運(yùn)行,在重要場合請謹(jǐn)慎使用)。DBCC INDEXDEFRAG和DBCC DBREINDEX是清除clustered和nonculstered索引碎片的兩個命令。

INDEXDEFRAG是一種在線操作(也就是說,它不會阻塞其它表格動作,如查詢),而DBREINDEX則在物理上重建索引。在絕大多數(shù)情況下,重建索引可以更好的消除碎片,但是這個優(yōu)點(diǎn)是以阻塞當(dāng)前發(fā)生在該索引所在表格上其它動作為代價換取來得。當(dāng)出現(xiàn)較大的碎片索引時,INDEXDEFRAG會花上一段比較長的時間,這是因?yàn)樵撁畹倪\(yùn)行是基于小的交互塊(transactional block)。

 

 

填充因子

 

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

 

在執(zhí)行查詢時,SQL Server動態(tài)選擇使用哪個索引。為此,SQL Server數(shù)據(jù)庫根據(jù)每個索引上分布在該關(guān)鍵字上的統(tǒng)計量來決定使用哪個索引。值得注意的是,經(jīng)過日常的數(shù)據(jù)庫活動(如插入、刪除和更新表格),SQL Server用到的這些統(tǒng)計量可能已經(jīng)“過期”了,需要更新。

你可以通過執(zhí)行DBCC SHOWCONTIG來查看統(tǒng)計量的狀態(tài)。當(dāng)你認(rèn)為統(tǒng)計量已經(jīng)“過期”時,你可以執(zhí)行該表格的UPDATE STATISTICS命令,這樣SQL Server就刷新了關(guān)于該索引的信息了。

 

 

建立數(shù)據(jù)庫維護(hù)計劃

 

SQL Server數(shù)據(jù)庫提供了一種簡化并自動維護(hù)數(shù)據(jù)庫的工具。這個稱之為數(shù)據(jù)庫維護(hù)計劃向?qū)В―atabase Maintenance Plan Wizard ,DMPW)的工具也包括了對索引的優(yōu)化。如果你運(yùn)行這個向?qū)?,你會看到關(guān)于數(shù)據(jù)庫中關(guān)于索引的統(tǒng)計量,這些統(tǒng)計量作為日志工作并定時更新,這樣就減輕了手工重建索引所帶來的工作量。

如果你不想自動定期刷新索引統(tǒng)計量,你還可以在DMPW中選擇重新組織數(shù)據(jù)和數(shù)據(jù)頁,這將停止舊有索引并按特定的填充因子重建索引。

【編輯推薦】

  1. SQL Server 數(shù)據(jù)庫中管理常用的SQL與T-SQL
  2. SQL Server業(yè)務(wù)規(guī)則的鏈接技術(shù)之探討
  3. SQL Server 2000的分頁存儲過程的改寫
  4. SQL Server數(shù)據(jù)庫對圖像數(shù)據(jù)之存儲機(jī)制
  5. SQL Server死鎖問題的解決與分析

 

責(zé)任編輯:佚名 來源: cnBeta.com
相關(guān)推薦

2010-07-15 14:46:20

SQL Server數(shù)

2010-07-08 17:33:21

SQL Server數(shù)

2010-07-09 11:28:12

SQL Server數(shù)

2011-08-22 12:01:36

SQL Server代碼優(yōu)化

2021-05-08 14:07:26

SQLServer數(shù)據(jù)庫

2009-07-06 21:20:34

SQL Server數(shù)

2010-05-10 18:54:12

Oracle數(shù)據(jù)庫索引

2010-06-28 14:56:24

優(yōu)化SQL Serve

2010-07-06 16:24:53

SQL Server數(shù)

2011-03-28 17:12:36

sql server數(shù)優(yōu)化

2009-03-11 15:40:20

2010-07-15 17:28:50

SQL Server

2019-08-19 11:07:41

SQL數(shù)據(jù)庫優(yōu)化

2009-01-27 21:00:00

服務(wù)器數(shù)據(jù)庫SQL Server

2010-07-07 10:31:43

SQL Server數(shù)

2011-08-16 09:05:21

SQL Server數(shù)測試索引空間換時間

2010-07-08 11:05:14

SQL Server數(shù)

2010-07-08 15:55:25

SQL Server

2011-04-06 11:16:47

SQL Server數(shù)查詢優(yōu)化

2010-06-17 13:34:47

SQL Server數(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號