mysql 索引的基礎操作彙總(四)

2022-09-26 00:18:13 字數 4033 閱讀 4930

1.為什麼使用索引:

資料庫物件中的索引其實和書的目錄類似,主要是為了提高從表中檢索資料的速度。由於資料儲存在資料庫表中,所以索引是建立在資料庫表物件上,由表中的乙個字段或者多個字段生成的鍵組成,這些鍵儲存在資料結構(b-樹或者雜湊表)中,通過mysql可以快速有效查詢與鍵相關聯的字段。根據索引的儲存型別,可以將索引分為b型樹索引(btree)和雜湊索引(hash)。注意:innodb和myisam儲存引擎支援btree型別索引,memory儲存引擎支援hash型別的索引,預設為前者索引。

mysql支援6種索引,分別是普通索程式設計客棧引、唯一索引、全文索引、單列索引、多列索引、空間索引。

以下情況適合建立索引:

1. 經常被查詢的字段。即在where子句**現的字段。

2. 在分組的字段,即在group by 子句**現的字段。

3. 存在依賴關係的子表和父表之間的聯合查詢,即主鍵或外來鍵字段。

4. 設定唯一完整約束的字段。

2.建立和檢視索引: 

索引的操作包括建立索引、檢視索引、 刪除索引。所謂建立索引,就是在表的乙個欄位或多個欄位上建立索引,在mysql中,可以通常三種方式來建立索引,建立表時建立索引、在已經存在的表上建立索引、通過sql語句alter table建立索引。 

2.1 建立和檢視普通索引: 

所謂普通索引就是在建立索引時,不附加任何限制條件(唯

一、非空等限制)。該型別的索引可以建立在任何型別的字段上。 

2.1.1 建立表時建立普通索引:

語法格式如下:

create table table_name(

屬性名 資料型別,

屬性名 資料型別,

......

屬性名 www.cppcns.com資料型別,

index|key [索引名] (屬性名1 [(長度)] [asc|desc])

);說明:index或者key引數用來指定欄位為索引,「索引名」引數用來指定所建立索引的名稱,「屬性名1」引數用來指定索引所關聯的字段的名稱,「長度」引數用來指定索引的長度,「asc|desc」引數用來指定公升序還是降序。

注意:在建立索引時,可以指定索引的長度。這是因為不同儲存引擎定義了表的最大索引數和最大索引長度。mysql所支援的儲存引擎對每個表至少支援16個索引,總索引長度至少256位元組。

示例:create table t_dept(

deptno int,

dname varchar(30),

loc varchar(40),

index index_deptno (deptno)

);說明:   可以通過 show create table t_dept \g 來檢視是否成功建立了索引;

可以通過 explain select * from t_dept where deptno=1\g;來校驗資料庫表中索引是否被使用。如果執行結果中的possible_keys和key欄位處的值都為所建立的索引名index_deptno,則說明該索引已經存在,而且已經開始啟用。

2.1.2 在已經存在的表上建立普通索引:

通過sql語句create index實現,其語法形式為:

create index 索引名

on 表名 (屬性名  [(長度)]  [adc|desc])

2.1.3 通過sql語句alter table 建立普通索引:

語法形式為:

alter table table_name add index|key 索引名 (屬性名 [(長度)] [asc|desc]);

2.2 建立和檢視唯一索引: 

所謂唯一索引,就是在建立索引時,限制索引的值必須是唯一的。通過該型別的索引可以更快的查詢某條記錄。在mysql中,根據建立索引的方式,可以分為自動索引和手動索引兩種。

所謂自動索引,是指在資料庫表裡設定完整性約束時,該錶會被系統自動建立索引。所謂手動索引,是指手動在表上建立索引。當設定表中的某個字段為主鍵或唯一完整性約束時,系統就會自動建立關聯該字段的唯一索引。 

2.2.1 建立表時建立唯一索引:

語法形式為:

create table table_name(

屬性名 資料型別,

屬性名 資料型別,

......

屬性名 資料型別,

unique index|key [索引名] (屬性名1 [(長度)] [asc | desc])

);說明:unique index或者unique key表示建立唯一索引。

2.2.2 在已經存在的表上建立唯一索引:

通過sql語句create unique index來實現,語法形式為:

create unique index 索引名

on 表名 (屬性名 [(長度)] [asc|desc]);

2.2.3 通過sql語句alter table建立唯一索引:

語法形式為:

alter table table_name add unique index|key 索引名 (屬性名 [(長度)] [asc|desc]);

2.3 建立和檢視全文索引: 

全文索引主要關聯在資料型別為char、varchar和text的字段上,以便能更加快速的查詢資料量較大的字串型別的字段。mysql只能在儲存引擎為myisam的資料庫表上建立全文引擎。預設情況下,全文引擎的搜尋執行方式為不區分大小寫,如果全文引擎所關聯的字段為二進位制資料型別,則以區分大小寫的方式執行。 

2.3.1 建立表時建立全文索引:

語法形式為:

create table table_name (

屬性名 資料型別,

屬性名 資料型別,

......

屬性名 資料型別,

fulltext index|key [索引名] (屬性名1 [(長度)] [asc|desc])

);2.3.2 在已經存在的表上建立全文索引:

語法形式為:

create fulltext index 索引名

on 表名 (屬性名 [(長度)] [asc|desc]);

2.3.3 通過sql語句alter table 建立全文索引:

語法形式為:

alter table table_name

add fulltext index|key 索引名 (屬性名 [(長度)] [asc|desc]);

2.4 建立和檢視多列索引: 

所謂多列索引,是指在建立索引時mvfsel,所關聯的字段不是乙個字段,而是多個字段。雖然可以通過所關聯的字段進行查詢,但是mvfsel只有查詢條件中使用了所關聯欄位中的第乙個字段,多列索引才會被使用。 

2.4.1 建立表時建立多列索引:

語法形式如下:

create table table_name(

屬性名 資料型別,

屬性名 資料型別,

......

屬性名 資料型別,

index|key [索引名]

(屬性名1 [(長度)] [asc|desc]),

......

(屬性名1 [(長度)] [asc|desc])

);上述語句建立索引時,所關聯的字段至少大於乙個字段。

2.4.2 在已經存在的表上建立多列索引:

語法形式為:

create index 索引名 on 表名 (

屬性名 [(長度)] [asc|desc],

......

屬性名n [(長度)] [asc|desc]

);2.4.3 通過sql語句altre table 建立多列索引:

語法形式為:

alter table table_name add index|key 索引名(屬性名 [(長度)] [asc|desc],屬性名n [(長度)] [asc|desc]);

3. 刪除索引:

刪除索引的語法形式:

drop index index_name on table_name

4. 檢視索引:

檢視索引的語法形式:

show index from table_name

本文標題: mysql 索引的基礎操作彙總(四)

本文位址: /shujuku/mysql/161853.html

MySQL(四)索引的操作

1.為什麼使用索引 資料庫物件中的索引其實和書的目錄類似,主要是為了提高從表中檢索資料的速度。由於資料儲存在資料庫表中,所以索引是建立在資料庫表物件上,由表中的乙個字段或者多個字段生成的鍵組成,這些鍵儲存在資料結構 b 樹或者雜湊表 中,通過mysql可以快速有效查詢與鍵相關聯的字段。根據索引的儲存...

mysql基礎操作彙總

資料庫操作 建立資料庫 create database dbname create database dbname character set utf8 查詢資料庫 show database 查詢所有資料庫名字 show create database dbname 查詢某一資料庫dbname的建...

mysql索引基礎 Mysql 索引基礎

什麼是索引?為什麼要建立索引?索引,其實就是目錄。索引,用於快速找出在某個列中有某個特定值的行。不使用索引,mysql必須從第一條記錄開始查詢整張表,直到找出相關的行,那麼表越大,查詢資料所花費的時間就越多。假如表中查詢的列有乙個索引 目錄 mysql能夠快速定位到達乙個位置去搜尋資料檔案,而不必查...