定義:索引是對資料庫表中一列或多列的值進行排序的一種結構,使用索引可快速訪問資料庫表中的特定資訊。
優點與缺點:建立索引的目的是加快對錶中記錄的查詢或排序。
為表設定索引要付出代價的:一是增加了資料庫的儲存空間,二是在插入和修改資料時要花費較多的時間(因為索引也要隨之變動)。
唯一索引唯一索引是不允許其中任何兩行具有相同索引值的索引。
當現有資料中存在重複的鍵值時,大多數資料庫不允許將新建立的唯一索引與表一起儲存。資料庫還可能防止新增將在表中建立重複鍵值的新資料。例如,如果在employee表中職員的姓(lname)上建立了唯一索引,則任何兩個員工都不能同姓。
主鍵索引
資料庫表經常有一列或列組合,其值唯一標識表中的每一行。該列稱為表的主鍵。
在資料庫關係圖中為表定義主鍵將自動建立主鍵索引,主鍵索引是唯一索引的特定型別。該索引要求主鍵中的每個值都唯一。當在查詢中使用主鍵索引時,它還允許對資料的快速訪問。
聚集索引
在聚集索引中,表中行的物理順序與鍵值的邏輯(索引)順序相同。乙個表只能包含乙個聚集索引。
如果某索引不是聚集索引,則表中行的物理順序與鍵值的邏輯順序不匹配。與非聚集索引相比,聚集索引通常提供更快的資料訪問速度。
例項:create table mytable(
idserial primary key,
category_id int not null default0,
user_id int not null default0,
adddate int not null default0
);
如果在查詢時常用類似以下的語句:
select * from mytable where category_id=1;
最直接的應對之道,是為category_id建立乙個簡單的索引:
create index mytable_categoryid on mytable (category_id);
select * from mytable where category_id=1 and user_id=2;
第一反應可能是,再給user_id建立乙個索引。不好,這不是乙個最佳的方法。可以建立多重的索引。
create index mytable_categoryid_userid on mytable(category_id,user_id);
select * from mytable
where category_id=1 and user_id=2
order by add date desc;
很簡單,就象為where字句中的字段建立乙個索引一樣,也為orderby的字句中的字段建立乙個索引:
create index mytable_categoryid_userid_adddate on mytable (category_id,user_id,adddate);
定義:索引是對資料庫表中一列或多列的值進行排序的一種結構,使用索引可快速訪問資料庫表中的特定資訊。
優點與缺點:建立索引的目的是加快對錶中記錄的查詢或排序。
為表設定索引要付出代價的:一是增加了資料庫的儲存空間,二是在插入和修改資料時要花費較多的時間(因為索引也要隨之變動)。
唯一索引唯一索引是不允許其中任何兩行具有相同索引值的索引。
當現有資料中存在重複的鍵值時,大多數資料庫不允許將新建立的唯一索引與表一起儲存。資料庫還可能防止新增將在表中建立重複鍵值的新資料。例如,如果在employee表中職員的姓(lname)上建立了唯一索引,則任何兩個員工都不能同姓。
主鍵索引
資料庫表經常有一列或列組合,其值唯一標識表中的每一行。該列稱為表的主鍵。
在資料庫關係圖中為表定義主鍵將自動建立主鍵索引,主鍵索引是唯一索引的特定型別。該索引要求主鍵中的每個值都唯一。當在查詢中使用主鍵索引時,它還允許對資料的快速訪問。
聚集索引
在聚集索引中,表中行的物理順序與鍵值的邏輯(索引)順序相同。乙個表只能包含乙個聚集索引。
如果某索引不是聚集索引,則表中行的物理順序與鍵值的邏輯順序不匹配。與非聚集索引相比,聚集索引通常提供更快的資料訪問速度。
例項:create table mytable(
idserial primary key,
category_id int not null default0,
user_id int not null default0,
adddate int not null default0
);
如果在查詢時常用類似以下的語句:
select * from mytable where category_id=1;
最直接的應對之道,是為category_id建立乙個簡單的索引:
create index mytable_categoryid on mytable (category_id);
select * from mytable where category_id=1 and user_id=2;
第一反應可能是,再給user_id建立乙個索引。不好,這不是乙個最佳的方法。可以建立多重的索引。
create index mytable_categoryid_userid on mytable(category_id,user_id);
select * from mytable
where category_id=1 and user_id=2
order by add date desc;
很簡單,就象為where字句中的字段建立乙個索引一樣,也為orderby的字句中的字段建立乙個索引:
create index mytable_categoryid_userid_adddate on mytable (category_id,user_id,adddate);
SQL Server資料庫 索引
描述 漢語字典中的漢字按頁存放,一般都有漢語拼音目錄 索引 偏旁部首目錄等 我們可以根據拼音或偏旁部首,快速查詢某個字詞 是sql server編排資料的內部方法。它為sql server提供一種方法來編排查詢資料 資料庫中儲存索引的資料頁 索引頁類似於漢語字 詞 典中按拼音或筆畫排序的目錄頁 通過...
資料庫基礎 索引(SQL Server)
參考原文 首先我們要知道資料庫索引是用來幹什麼的 索引是為了加快資料查詢速度而引入的,資料庫中儲存的資料在物理層是隨機儲存的,對某個列建立索引就會對該列的關鍵值進行排序並用某種資料結構儲存他的值和對應的實體地址,在sql中用的資料結構是b樹。索引的分類 1.聚集索引 聚集索引會對資料按索引按索引關鍵...
SQL server 資料庫之「索引」詳解
什麼是索引?資料庫中的索引與書籍中的目錄類似,索引使sql server編排資料的內部方法,它為sql server提供一種方法來編排查詢資料的路由。索引頁是資料中儲存索引的資料頁。索引頁存放檢索資料行的關鍵字頁及該資料行的位址指標。通過使用索引,可以大大提高資料庫的檢索速度 改善資料庫效能。索引的...