1. 1.索引作用
2. 在索引列上,除了上面提到的有序查詢之外,資料庫利用各種各樣的快速定位技術,能夠大大提高查詢效率。特別是當資料量非常大,查詢涉及多個表時,使用索引往往能使查詢速度加快成千上萬倍。 3.
4. 例如,有3個未索引的表t1、t2、t3,分別只包含列c1、c2、c3,每個表分別含有1000行資料組成,指為1~1000的數值,查詢對應值相等行的查詢如下所示。 5.
6. select c1,c2,c3 from t1,t2,t3 where c1=c2 and c1=c3 7.
8. 此查詢結果應該為1000行,每行包含3個相等的值。在無索引的情況下處理此查詢,必須尋找3個表所有的組合,以便得出與where子句相配的那些行。而可能的組合數目為1000×1000×1000(十億),顯然查詢將會非常慢。 9.
10. 如果對每個表進行索引,就能極大地加速查詢程序。利用索引的查詢處理如下。 11.
12.(1)從表t1中選擇第一行,檢視此行所包含的資料。 13.
14.(2)使用表t2上的索引,直接定位t2中與t1的值匹配的行。類似,利用表t3上的索引,直接定位t3中與來自t1的值匹配的行。 15. 16.(3)掃瞄表t1的下一行並重複前面的過程,直到遍歷t1中所有的行。 17.
18. 在此情形下,仍然對錶t1執行了乙個完全掃瞄,但能夠在表t2和t3上進行索引查詢直接取出這些表中的行,比未用索引時要快一百萬倍。 19.
20. 利用索引,mysql加速了where子句滿足條件行的搜尋,而在多表連線查詢時,在執行連線時加快了與其他表中的行匹配的速度。 21.
22.2. 建立索引
23.在執行create table語句時可以建立索引,也可以單獨用create index或alter table來為表增加索引。 24.
25.1.alter table
26.alter table用來建立普通索引、unique索引或primary key索引。 27. 28. 29.
30.alter table table_name add index index_name (column_list) 31.
32.alter table table_name add unique (column_list)
閱讀會員限時特惠 7大會員特權立即嘗鮮
33.
34.alter table table_name add primary key (column_list) 35. 36. 37.
38.其 中table_name是要增加索引的表名,column_list指出對哪些列進行索引,多列時各列之間用逗號分隔。索引名index_name可選, 預設時,mysql將根據第乙個索引列賦乙個名稱。另外,alter table允許在單個語句中更改多個表,因此可以在同時建立多個索引。 39.
40.2.create index
41.create index可對表增加普通索引或unique索引。 42. 43. 44.
45.create index index_name on table_name (column_list) 46.
47.create unique index index_name on table_name (column_list) 48. 49. 50.
51.table_name、index_name和column_list具有與alter table語句中相同的含義,索引名不可選。另外,不能用create index語句建立primary key索引。 52.
53.3.索引型別
54.在建立索引時,可以規定索引能否包含重複值。如果不包含,則索引應該建立為primary key或unique索引。對於單列惟一性索引,這保證單列不包含重複的值。對於多列惟一性索引,保證多個值的組合不重複。 55.
56.primary key索引和unique索引非常類似。事實上,primary key索引僅是乙個具有名稱primary的unique索引。這表示乙個表只能包含乙個primary key,因為乙個表中不可能具有兩個同名的索引。 57.
58.下面的sql語句對students表在sid上新增primary key索引。 59. 60. 61.
62.alter table students add primary key (sid) 63.
64.4. 刪除索引
65.可利用alter table或drop index語句來刪除索引。類似於
create index語句,drop index可以在alter table內部作為一條語句處理,語法如下。
66. 67. 68.
69.drop index index_name on talbe_name 70.
71.alter table table_name drop index index_name 72.
73.alter table table_name drop primary key 74. 75. 76. 77.其中,前兩條語句是等價的,刪除掉table_name中的索引index_name。 78.
79.第3條語句只在刪除primary key索引時使用,因為乙個表只可能有乙個primary key索引,因此不需要指定索引名。如果沒有建立primary key索引,但表具有乙個或多個unique索引,則mysql將刪除第乙個unique索引。 80.
81.如果從表中刪除了某列,則索引會受到影響。對於多列組合的索引,如果刪除其中的某列,則該列也會從索引中刪除。如果刪除組成索引的所有列,則整個索引將被刪除。 82. 83.
84.5.檢視索引 85.
86.mysql> show index from tblname; 87.
88.mysql> show keys from tblname; 89.
90. · table 91.
92. 表的名稱。 93.
94. · non_unique 95.
96. 如果索引不能包括重複詞,則為0。如果可以,則為1。 97.
98. · key_name 99.
100. 索引的名稱。 101.
102. · seq_in_index 103.
104. 索引中的列序列號,從1開始。
105.
106. · column_name 107.
108. 列名稱。 109.
110. · collation 111.
112. 列以什麼方式儲存在索引中。在mysql中,有值『a』(公升序)或null(無分類)。 113.
114. · cardinality 115.
116. 索引中唯一值的數目的估計值。通過執行analyze table或myisamchk -a可以更新。基數根據被儲存為整數的統計資料來計數,所以即使對於小型表,該值也沒有必要是精確的。基數越大,當進行聯合時,mysql使用該索引的機會就越大。 117.
118. · sub_part 119.
120. 如果列只是被部分地編入索引,則為被編入索引的字元的數目。如果整列被編入索引,則為null。 121.
122. · packed 123.
124. 指示關鍵字如何被壓縮。如果沒有被壓縮,則為null。 125.
126. · null 127.
128. 如果列含有null,則含有yes。如果沒有,則該列含有no。 129.
130. · index_type 131.
132. 用過的索引方法(btree, fulltext, hash, rtree)
資料庫 資料庫索引
索引是儲存引擎用於快速找到記錄的一種資料結構。索引以檔案的形式儲存在磁碟中。索引可以包含乙個或多個列的值。儲存引擎查詢資料的時候,先在索引中找對應值,然後根據匹配的索引記錄找到對應的資料行。1.b tree索引 2.雜湊索引 myisam和innodb儲存引擎 只支援btree索引,也就是說預設使用...
資料庫mysql索引 資料庫 mysql索引
mysql 索引 mysql索引的建立對於mysql的高效執行是很重要的,索引可以大大提高mysql的檢索速度。打個比方,如果合理的設計且使用索引的mysql是一輛蘭博基尼的話,那麼沒有設計和使用索引的mysql就是乙個人力三輪車。索引分單列索引和組合索引。單列索引,即乙個索引只包含單個列,乙個表可...
資料庫索引
索引 索引列唯一索引 主鍵索引 聚簇索引和非聚簇索引 如何建立索引 如何刪除索引 使用索引可快速訪問資料庫表中的特定資訊。索引是對資料庫表中一列或多列的值進行排序的一種結構,例如 employee 表的姓 lname 列。如果要按姓查詢特定職員,與必須搜尋表中的所有行相比,索引會幫助您更快地獲得該資...