資源描述:
《索引和索引調(diào)整向?qū)?-》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在應(yīng)用文檔-天天文庫。
1、索引和索引調(diào)整向?qū)?> 概述 數(shù)據(jù)庫的目的就是管理大量的數(shù)據(jù)。隨著知識經(jīng)濟的迅猛發(fā)展和信息技術(shù)水平的飛速提高,信息技術(shù)的應(yīng)用越來越廣泛,涉及的領(lǐng)域越來越多,從企業(yè)到學(xué)校,從政府到個人,幾乎都席卷到了這個信息浪潮中。高速膨脹的需求,對數(shù)據(jù)庫技術(shù)提出了更多更高更難的要求,例如要求處理的數(shù)據(jù)量越來越多、要求的處理速度越來越快。為了處理更多的數(shù)據(jù)量,例如太字節(jié)(TB)的數(shù)據(jù),這就要求數(shù)據(jù)庫采用新的存儲引擎,并且可以處理來自各種數(shù)據(jù)源的數(shù)據(jù)。為了提高數(shù)據(jù)的處理速度,在數(shù)據(jù)庫查詢技術(shù)方面,要求采用新的查詢模型、并行查詢方式和新的索引技術(shù)。許多數(shù)據(jù)庫供應(yīng)商各出新招
2、,紛紛推出自己的適應(yīng)新形式的解決方案。微軟公司作為在信息技術(shù)領(lǐng)域中成長最快的影響最大的計算機公司,也推出了自己的面向二十一世紀(jì)的數(shù)據(jù)庫解決方案,這就是SQLServer7.0?! QLServer7.0在許多數(shù)據(jù)庫產(chǎn)品中之所以能夠成為領(lǐng)先者,就是因為它為了滿足客戶的需求,在易用性、可伸縮性、可靠性和數(shù)據(jù)庫倉庫方面進行了許多革新。這些革新包括許多方面,例如SQLServer7.0是第一個能夠縮放以適應(yīng)從便攜式計算到企業(yè)級應(yīng)用的各種規(guī)模的數(shù)據(jù)庫,從MB級到GB級、從GB級到TB級,它們可以使用完全相同的代碼,數(shù)據(jù)庫提供了100%的代碼兼容性。SQLServ
3、er7.0還是第一個支持自配置和自調(diào)整的數(shù)據(jù)庫、第一個與OLAP服務(wù)器集成的數(shù)據(jù)庫、第一個與數(shù)據(jù)轉(zhuǎn)換服務(wù)集成的數(shù)據(jù)庫、第一個提供了多服務(wù)器管理以適應(yīng)大量服務(wù)器應(yīng)用的數(shù)據(jù)庫、第一個數(shù)據(jù)倉庫框架成為解決元數(shù)據(jù)問題的綜合方法、提供了對任意類型數(shù)據(jù)庫的最廣泛的復(fù)制選項,微軟的全局數(shù)據(jù)存取策略實現(xiàn)了對大量信息資源的高性能訪問。本文主要介紹有關(guān)索引和索引調(diào)整向?qū)У膬?nèi)容。 概念和特點 索引就是加快檢索表中數(shù)據(jù)的方法。數(shù)據(jù)庫的索引類似于書籍的索引。在書籍中,索引允許用戶不必翻閱完整個書就能迅速地找到所需要的信息。在數(shù)據(jù)庫中,索引也允許數(shù)據(jù)庫程序迅速地找到表中的數(shù)據(jù),
4、而不必掃描整個數(shù)據(jù)庫。在書籍中,索引就是內(nèi)容和相應(yīng)頁號的清單。在數(shù)據(jù)庫中,索引就是表中數(shù)據(jù)和相應(yīng)存儲位置的列表。索引可以大大減少數(shù)據(jù)庫管理系統(tǒng)查找數(shù)據(jù)的時間。索引調(diào)整向?qū)且环N工具,它通過使用查詢優(yōu)化器來分析工作量中的查詢?nèi)蝿?wù),向有大量工作量的數(shù)據(jù)庫推薦一種最佳的索引混合方式,加快數(shù)據(jù)庫的查詢速度。SQLServer現(xiàn)在用交叉索引和聯(lián)合索引來完成對一個數(shù)據(jù)庫的多次索引?! ∷饕退饕{(diào)整向?qū)Ь哂邢铝幸恍┨攸c: 索引可以加快數(shù)據(jù)庫的檢索速度 索引降低了數(shù)據(jù)庫插入、修改、刪除等維護任務(wù)的速度 索引創(chuàng)建在表上,不能創(chuàng)建在視圖上 索引有兩種類型,即聚簇索
5、引和非聚簇索引 聚簇索引與基表的物理順序相同,非聚簇索引與基表的物理順序不相同 索引既可以直接創(chuàng)建,也可以間接創(chuàng)建 可以在優(yōu)化隱藏中,使用索引 使用查詢處理器執(zhí)行SQL語句,在一個表上,一次只能使用一個索引 使用索引調(diào)整向?qū)?,在一個表上,一次可以使用多個索引 使用索引調(diào)整向?qū)В枰峁┕ぷ髁孔鳛檎{(diào)整的對象 索引的優(yōu)點和缺點 為什么要創(chuàng)建索引呢?這是因為,創(chuàng)建索引可以大大提高系統(tǒng)的性能。第一,通過創(chuàng)建唯一性索引,可以保證數(shù)據(jù)庫表中每一行數(shù)據(jù)的唯一性。第二,可以大大加快數(shù)據(jù)的檢索速度,這也是創(chuàng)建索引的最主要的原因。第三,可以加速表和表之間的連
6、接,特別是在實現(xiàn)數(shù)據(jù)的參考完整性方面特別有意義。第四,在使用分組和排序子句進行數(shù)據(jù)檢索時,同樣可以顯著減少查詢中分組和排序的時間。第五,通過使用索引,可以在查詢的過程中,使用優(yōu)化隱藏器,提高系統(tǒng)的性能?! ∫苍S會有人要問:增加索引有如此多的優(yōu)點,為什么不對表中的每一個列創(chuàng)建一個索引呢?這種想法固然有其合理性,然而也有其片面性。雖然,索引有許多優(yōu)點,但是,為表中的每一個列都增加索引,是非常不明智的。這是因為,增加索引也有許多不利的一個方面。第一,創(chuàng)建索引和維護索引要耗費時間,這種時間隨著數(shù)據(jù)量的增加而增加。第二,索引需要占物理空間,除了數(shù)據(jù)表占數(shù)據(jù)空間之外
7、,每一個索引還要占一定的物理空間,如果要建立聚簇索引,那么需要的空間就會更大。第三,當(dāng)對表中的數(shù)據(jù)進行增加、刪除和修改的時候,索引也要動態(tài)的維護,這樣就降低了數(shù)據(jù)的維護速度。 索引是建立在數(shù)據(jù)庫表中的某些列的上面。因此,在創(chuàng)建索引的時候,應(yīng)該仔細考慮在哪些列上可以創(chuàng)建索引,在哪些列上不能創(chuàng)建索引。一般來說,應(yīng)該在這些列上創(chuàng)建索引,例如:在經(jīng)常需要搜索的列上,可以加快搜索的速度;在作為主鍵的列上,強制該列的唯一性和組織表中數(shù)據(jù)的排列結(jié)構(gòu);在經(jīng)常用在連接的列上,這些列主要是一些外鍵,可以加快連接的速度;在經(jīng)常需要根據(jù)范圍進行搜索的列上創(chuàng)建索引,因為索引已經(jīng)
8、排序,其指定的范圍是連續(xù)的;在經(jīng)常需要排序的列上創(chuàng)建索引,因為索引已經(jīng)排序,這樣