sql server 索引学习1
1 什么是聚集和非聚集索引
SQL SERVER提供兩種索引:聚集索引(clustered index,也稱聚類索引、簇集索引)和非聚集索引(nonclustered index,也稱非聚類索引、非簇集索引)。
其實,我們的漢語字典的正文本身就是一個聚集索引。比如,我們要查“安”字,就會很自然地翻開字典的前幾頁,因為“安”的拼音是“an”,而按照拼音排序漢字的字典是以英文字母“a”開頭并以“z”結尾的,那么“安”字就自然地排在字典的前部。如果您翻完了所有以“a”開頭的部分仍然找不到這個字,那么就說明您的字典中沒有這個字;同樣的,如果查“張”字,那您也會將您的字典翻到最后部分,因為“張”的拼音是“zhang”。也就是說,字典的正文部分本身就是一個目錄,您不需要再去查其他目錄來找到您需要找的內容。我們把這種正文內容本身就是一種按照一定規則排列的目錄稱為“聚集索引”。
如果您認識某個字,您可以快速地從自動中查到這個字。但您也可能會遇到您不認識的字,不知道它的發音,這時候,您就不能按照剛才的方法找到您要查的字,而需要去根據“偏旁部首”查到您要找的字,然后根據這個字后的頁碼直接翻到某頁來找到您要找的字。但您結合“部首目錄”和“檢字表”而查到的字的排序并不是真正的正文的排序方法,比如您查“張”字,我們可以看到在查部首之后的檢字表中“張”的頁碼是672頁,檢字表中“張”的上面是“馳”字,但頁碼卻是63頁,“張”的下面是“弩”字,頁面是390頁。很顯然,這些字并不是真正的分別位于“張”字的上下方,現在您看到的連續的“馳、張、弩”三字實際上就是他們在非聚集索引中的排序,是字典正文中的字在非聚集索引中的映射。我們可以通過這種方式來找到您所需要的字,但它需要兩個過程,先找到目錄中的結果,然后再翻到您所需要的頁碼。我們把這種目錄純粹是目錄,正文純粹是正文的排序方式稱為“非聚集索引”。
每個表只能有一個聚集索引,因為目錄只能按照一種方法進行排序。
2?何時使用聚集索引或非聚集索引
3 索引操作示例語句
-- 創建唯一聚集索引 create unique clustered --表示創建唯一聚集索引 index UQ_Clu_StuNo --索引名稱 on Student(S_StuNo) --數據表名稱(建立索引的列名) with (pad_index=on, --表示使用填充fillfactor=50, --表示填充因子為50%ignore_dup_key=on, --表示向唯一索引插入重復值會忽略重復值statistics_norecompute=off --表示啟用統計信息自動更新功能 )-- 創建唯一非聚集索引 create unique nonclustered --表示創建唯一非聚集索引 index UQ_NonClu_StuNo --索引名稱 on Student(S_StuNo) --數據表名稱(建立索引的列名) with (pad_index=on, --表示使用填充fillfactor=50, --表示填充因子為50%ignore_dup_key=on, --表示向唯一索引插入重復值會忽略重復值statistics_norecompute=off --表示啟用統計信息自動更新功能 )--創建聚集索引 create clustered index Clu_Index on Student(S_StuNo) with (drop_existing=on) --創建非聚集索引 create nonclustered index NonClu_Index on Student(S_StuNo) with (drop_existing=on) --創建唯一索引 create unique index NonClu_Index on Student(S_StuNo) with (drop_existing=on)create nonclustered index Index_StuNo_SName on Student(S_StuNo,S_Name) with(drop_existing=on) --創建非聚集復合索引,未指定默認為非聚集索引 create index Index_StuNo_SName on Student(S_StuNo,S_Name) with(drop_existing=on)--創建非聚集覆蓋索引 create nonclustered index NonClu_Index on Student(S_StuNo) include (S_Name,S_Height) with(drop_existing=on)--創建非聚集覆蓋索引,未指定默認為非聚集索引 create index NonClu_Index on Student(S_StuNo) include (S_Name,S_Height) with(drop_existing=on)--查看指定表 Student 中的索引 exec sp_helpindex Student --刪除指定表 Student 中名為 Index_StuNo_SName 的索引 drop index Student.Index_StuNo_SName--檢查表 Student 中索引 UQ_S_StuNo 的碎片信息 dbcc showcontig(Student,UQ_S_StuNo)--整理 Test 數據庫中表 Student 的索引 UQ_S_StuNo 的碎片 dbcc indexdefrag(Test,Student,UQ_S_StuNo)--更新表 Student 中的全部索引的統計信息 update statistics Student參考
https://msdn.microsoft.com/zh-cn/library/ms188783.aspx
總結
以上是生活随笔為你收集整理的sql server 索引学习1的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 常用SQL语句优化技巧总结
- 下一篇: Matlab画线实例图