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