學(xué)習(xí)筆記

          Simple is beautiful.

          導(dǎo)航

          <2007年6月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          1234567

          統(tǒng)計

          公告

          ...

          常用鏈接

          留言簿(1)

          隨筆分類(2)

          隨筆檔案(56)

          Weblog

          搜索

          最新評論

          評論排行榜

          數(shù)據(jù)庫中的索引

          可以利用索引快速訪問數(shù)據(jù)庫表中的特定信息。索引是對數(shù)據(jù)庫表中一個或多個列(例如,table1 表的姓氏 (id) 列)的值進行排序的結(jié)構(gòu)。如果想按特定職員的姓來查找他或她,則與在表中搜索所有的行相比,索引有助于更快地獲取信息。
          索引提供指針以指向存儲在表中指定列的數(shù)據(jù)值,然后根據(jù)指定的排序次序排列這些指針。數(shù)據(jù)庫使用索引的方式與使用書的目錄很相似:通過搜索索引找到特定的值,然后跟隨指針到達包含該值的行。
          在數(shù)據(jù)庫關(guān)系圖中,可以為選定的表創(chuàng)建、編輯或刪除索引/鍵屬性頁中的每個索引類型。當(dāng)保存附加在此索引上的表或包含此表的數(shù)據(jù)庫關(guān)系圖時,索引同時被保存。
          通常情況下,只有當(dāng)經(jīng)常查詢索引列中的數(shù)據(jù)時,才需要在表上創(chuàng)建索引。索引將占用磁盤空間,并且降低添加、刪除和更新行的速度。不過在多數(shù)情況下,索引所帶來的數(shù)據(jù)檢索速度的優(yōu)勢大大超過它的不足之處。然而,如果應(yīng)用程序非常頻繁地更新數(shù)據(jù),或磁盤空間有限,那么最好限制索引的數(shù)量。
          在創(chuàng)建索引前,必須確定要使用的列和要創(chuàng)建的索引類型。

           

          索引類型
          索引列
          可基于數(shù)據(jù)庫表中的單列或多列創(chuàng)建索引。當(dāng)某些行中的某一列具有相同的值時,多列索引能區(qū)分開這些行。
          如果經(jīng)常在同時搜索兩列或多列或按兩列或多列排序時,索引也很有幫助。例如,如果經(jīng)常在同一查詢中為姓和名兩列設(shè)置準(zhǔn)則,那么在這兩列上創(chuàng)建多列索引將很有意義。
          確定索引的有效性:
          檢查查詢中的 WHERE 和 JOIN 子句。在任一子句中包括的每一列都是索引可以選擇的對象。

          試驗新的索引,檢查它對運行查詢性能的影響。

          考慮表中已創(chuàng)建的索引數(shù)量。最好不要在一個表中創(chuàng)建大量的索引。

          檢查表中已創(chuàng)建的索引定義。最好避免包含共享列的重疊索引。

          檢查列中唯一數(shù)據(jù)值的數(shù)量,并與表中的行數(shù)進行比較。比較的結(jié)果就是該列的可選擇性,這有助于確定該列是否適合建立索引,如果適合,確定索引的類型是什么。
          索引類型
          根據(jù)數(shù)據(jù)庫的功能,可在數(shù)據(jù)庫設(shè)計器中創(chuàng)建三種類型的索引 — 唯一索引、主鍵索引和聚集索引。

          唯一索引
          唯一索引不允許兩行具有相同的索引值。
          如果現(xiàn)有數(shù)據(jù)中存在重復(fù)的鍵值,則大多數(shù)數(shù)據(jù)庫都不允許將新創(chuàng)建的唯一索引與表一起保存。當(dāng)新數(shù)據(jù)將使表中的鍵值重復(fù)時,數(shù)據(jù)庫也拒絕接受此數(shù)據(jù)。例如,如果在 employee 表中的職員姓氏 (lname) 列上創(chuàng)建了唯一索引,則所有職員不能同姓。
          主鍵索引
          數(shù)據(jù)庫表通常有一列或列組合,其值用來唯一標(biāo)識表中的每一行。該列稱為表的主鍵。
          在數(shù)據(jù)庫關(guān)系圖中為表定義一個主鍵將自動創(chuàng)建主鍵索引,主鍵索引是唯一索引的特殊類型。主鍵索引要求主鍵中的每個值是唯一的。當(dāng)在查詢中使用主鍵索引時,它還允許快速訪問數(shù)據(jù)。。
          聚集索引
          在聚集索引中,表中各行的物理順序與鍵值的邏輯(索引)順序相同。表只能包含一個聚集索引。
          如果不是聚集索引,表中各行的物理順序與鍵值的邏輯順序不匹配。聚集索引比非聚集索引有更快的數(shù)據(jù)訪問速度。

          posted on 2007-06-09 01:57 Ecko 閱讀(668) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 毕节市| 镇远县| 富平县| 斗六市| 托里县| 百色市| 沁水县| 海安县| 丹巴县| 自贡市| 桑日县| 德阳市| 东兴市| 普定县| 新竹市| 吉木萨尔县| 奎屯市| 同德县| 繁峙县| 深水埗区| 黔东| 永平县| 龙川县| 册亨县| 宜兴市| 五家渠市| 普格县| 于都县| 德格县| 额济纳旗| 兴安县| 泽库县| 武安市| 南安市| 织金县| 巴青县| 云南省| 通渭县| 汉中市| 朝阳市| 黑河市|