亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

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

2024-07-24 13:10:23
字體:
來源:轉載
供稿:網友

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( 屬性名 數據類型, 屬性名 數據類型, ...... 屬性名 數據類型, 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 創建和查看多列索引: 
    所謂多列索引,是指在創建索引時,所關聯的字段不是一個字段,而是多個字段。雖然可以通過所關聯的字段進行查詢,但是只有查詢條件中使用了所關聯字段中的第一個字段,多列索引才會被使用。 
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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品国产一区二区三区在线观看| 欧美体内谢she精2性欧美| xxxx欧美18另类的高清| 久久久精品美女| 动漫精品一区二区| 欧美日韩第一页| 美女国内精品自产拍在线播放| 都市激情亚洲色图| 中文字幕亚洲一区| 欧洲午夜精品久久久| 亚洲石原莉奈一区二区在线观看| 麻豆成人在线看| 久久久精品亚洲| 日韩视频免费中文字幕| 日韩资源在线观看| 亚洲高清久久网| 国产精品一区久久| 日本中文字幕久久看| 欧美激情亚洲自拍| 日韩av快播网址| 亚洲va欧美va国产综合久久| 中文国产成人精品久久一| 国产欧美一区二区白浆黑人| 久久久999精品视频| 91精品久久久久久久久| 欧美日韩黄色大片| 日韩www在线| 国产美女精品免费电影| 大量国产精品视频| 亚洲国产日韩一区| 18性欧美xxxⅹ性满足| 国产亚洲xxx| 亚洲成人激情视频| 亚洲国产美女精品久久久久∴| 欧美激情第6页| 中文字幕精品www乱入免费视频| 日本伊人精品一区二区三区介绍| 成人福利视频在线观看| 欧美日韩不卡合集视频| 久久亚洲精品一区| 亚洲男女自偷自拍图片另类| xxxxxxxxx欧美| 日韩av电影在线免费播放| 久久久久999| 精品久久久久久亚洲国产300| 国产一区二区三区日韩欧美| 亚洲高清免费观看高清完整版| 国产99视频精品免视看7| 国产欧美精品一区二区三区-老狼| 国产一区二区黑人欧美xxxx| 亚洲第一精品夜夜躁人人躁| 欧美又大粗又爽又黄大片视频| 成人在线观看视频网站| 久久免费视频在线| 欧美日韩国产一区中文午夜| 欧美大成色www永久网站婷| 国产精品女视频| 久久天天躁狠狠躁夜夜av| 欧美一级片在线播放| 国产在线精品成人一区二区三区| www.日韩欧美| 丝袜亚洲另类欧美重口| 欧美成人国产va精品日本一级| 热门国产精品亚洲第一区在线| 欧美激情成人在线视频| 久久久免费高清电视剧观看| 午夜精品三级视频福利| 日韩av电影免费观看高清| 国产亚洲精品久久久久久| 亚洲人成网站色ww在线| 欧美—级a级欧美特级ar全黄| 国产精品日韩专区| 成人福利在线观看| 中文字幕国内精品| 久久久精品一区二区三区| 日本精品久久久久久久| 欧美另类精品xxxx孕妇| 国产一区二区三区四区福利| 国产福利精品av综合导导航| 日韩在线观看免费高清完整版| 欧美一级片一区| 欧美黄色片在线观看| 日韩av影片在线观看| 91色中文字幕| 这里只有精品在线观看| 国产乱肥老妇国产一区二| 欧美人与性动交| 国产成人久久久| 亚洲一级黄色片| 日韩中文视频免费在线观看| 欧美在线观看一区二区三区| 国产伊人精品在线| 91久久国产婷婷一区二区| 日韩hd视频在线观看| 91在线视频免费| 成人中心免费视频| 亚洲成人网av| 日韩中文字幕在线免费观看| 亚洲国产精品字幕| 国产午夜精品视频免费不卡69堂| 日本在线精品视频| 亚洲视频在线免费观看| 久久久久久久久久国产精品| 精品无人国产偷自产在线| 国产精品福利久久久| 性色av香蕉一区二区| 国产精品国模在线| 精品国产一区av| 97精品欧美一区二区三区| 国产亚洲欧洲高清一区| 精品小视频在线| 亚洲精品视频网上网址在线观看| 欧美在线视频网| 国产亚洲精品91在线| 成人免费福利视频| 国产精品久久久999| 亚洲欧美综合v| 国产精品视频精品视频| 91精品在线播放| 91麻豆国产语对白在线观看| 成人免费看片视频| 精品国产电影一区| 中文日韩在线观看| 国产经典一区二区| 欧美野外wwwxxx| 日韩精品在线观看视频| 久久国产精品影片| 成人乱人伦精品视频在线观看| 97视频在线观看免费高清完整版在线观看| 国产精品久久久久久久9999| 成人国产在线视频| 亚洲夜晚福利在线观看| 日韩在线观看网站| 这里只有精品视频在线| 91精品国产91久久久久久吃药| 欧美成人激情在线| 亚洲欧美日韩天堂| 91视频国产精品| 国产一区二区三区高清在线观看| 95av在线视频| 91久久精品久久国产性色也91| 日韩一区二区欧美| 亚洲国产欧美一区二区三区久久| 成人久久一区二区| 性日韩欧美在线视频| 欧美一区二区三区免费观看| 国语自产精品视频在线看抢先版图片| 最近的2019中文字幕免费一页| 欧洲成人午夜免费大片| 国产一区二区免费| 欧美中文字幕视频在线观看| 欧美日韩激情美女| 国产一区二区三区在线看| 欧美亚洲国产另类| 久久精品视频亚洲| 欧美一区三区三区高中清蜜桃| 国产精品三级美女白浆呻吟| 97视频在线观看视频免费视频| 日韩美女视频免费在线观看| 精品久久久久久中文字幕大豆网| 国产色综合天天综合网| 国产日韩亚洲欧美| 精品国产依人香蕉在线精品| 亚洲福利视频二区|