色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL索引的基本語法

瀏覽:6日期:2023-10-13 10:03:54

索引是排好序的數(shù)據(jù)結(jié)構(gòu)!可以用在 where 條件查找的字段,和order by 排序的字段,有了索引,便可以快速地定位數(shù)據(jù)所在的物理地址并找出來。

索引的分類

1.普通索引(normal):沒有任何約束,主要用于提高查詢效率

2.唯一索引(UNIQUE):在普通索引的基礎(chǔ)上增加了數(shù)據(jù)唯一性的約束,可以有多個

3.主鍵索引(primary key):主鍵索引在唯一索引的基礎(chǔ)上增加了不為空的約束,也就是 NOT NULL+UNIQUE,只能有一個

4.全文索引(FULLTEXT):MySQL 自帶的全文索引只支持英文。

一般使用專門的全文搜索引擎,比如 ES(ElasticSearch)

創(chuàng)建索引

#普通索引

ALTER TABLE 表名 ADD INDEX 索引名 (column_list);

#唯一索引

ALTER TABLE 表名 ADD UNIQUE 索引名(column_list);

#主鍵索引

ALTER TABLE 表名 ADD PRIMARY KEY 索引名(column_list);

#全文索引(字符串數(shù)據(jù)類型)

ALTER TABLE 表名 ADD fulltext 索引名(column_list);

#查看索引

show index from student G

這里用G 代替分號結(jié)束符;可以格式化輸出數(shù)據(jù)信息。

#刪除索引

修改表的方式刪除索引

ALTER TABLE 表名 DROP INDEX 索引名;

刪除主鍵索引

ALTER TABLE 表名 DROP PRIMARY KEY;

索引列為一列時為單一索引;多個列組合在一起創(chuàng)建的索引叫做聯(lián)合索引

什么情況下可以創(chuàng)建索引?

1.字段的數(shù)值有唯一性的限制,比如id

2.頻繁作為 WHERE 查詢條件的字段,尤其在數(shù)據(jù)表大的情況下

如果在數(shù)據(jù)量非常大的情況下,沒有 WHERE 條件過濾是非常可怕的。

3.需要經(jīng)常 GROUP BY 和 ORDER BY 的列

4.UPDATE、DELETE 的 WHERE 條件列,一般也需要創(chuàng)建索引

原理是因為我們需要先根據(jù) WHERE 條件列檢索出來這條記錄,然后再對它進行更新或刪除,非索引字段更新數(shù)據(jù)效果更明顯;

如果索引太多了,在更新數(shù)據(jù)的時候,如果涉及到索引更新,就會造成負擔。

5.DISTINCT 字段需要創(chuàng)建索引

6.做多表 JOIN 連接操作時,創(chuàng)建索引需要注意以下的原則

連接表的數(shù)量盡量不要超過 3 張,每增加一張表就相當于增加了 一次嵌套的循環(huán),數(shù)量級增長會非常快 對用于連接的字段創(chuàng)建索引,并且該字段在多張表中的類型必須一致。

什么時候不需要創(chuàng)建索引?

索引的價值是快速定位,如果起不到定位的字段通常是不需要創(chuàng)建索引的

1.WHERE 條件(包括 GROUP BY、ORDER BY)里用不到的字段不需要創(chuàng)建索引;

2.表記錄太少,比如少于 1000 行,那么是不需要創(chuàng)建索引;

3.字段中如果有大量重復數(shù)據(jù),也不用創(chuàng)建索引,比如性別字段;

4.頻繁更新的字段不一定要創(chuàng)建索引。因為更新數(shù)據(jù)的時候,也需要更新索引,如果索引太多,在更新索引的時候也會造成負擔,從而影響效率;

什么情況下索引失效?

1.如果索引列進行了表達式計算,使用函數(shù),則會失效

2.在 WHERE 子句中,如果在 OR 前的條件列進行了索引,而在 OR 后的條件列沒有進行索引,那么索引會失效。

3.當我們使用 LIKE 進行模糊查詢的時候,表達式不能是 % 開始

4.索引列盡量設(shè)置為 NOT NULL 約束

判斷索引列是否為 NOT NULL,往往需要走全表掃描,因此我們最好在設(shè)計數(shù)據(jù)表的時候就將字段設(shè)置為 NOT NULL 約束比如你可以將 INT 類型的字段,默認值設(shè)置為 0。將字符類型的默認值設(shè)置為空字符串 (’’)

以上就是MySQL索引的基本語法的詳細內(nèi)容,更多關(guān)于MySQL索引語法的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

相關(guān)文章:
主站蜘蛛池模板: 国产成人a大片大片在线播放 | 亚洲欧美成人在线 | 亚洲成在人线免费视频 | baby在线观看免费观看 | 欧美人交性视频在线香蕉 | 亚洲日韩中文字幕 | 亚洲视频天堂 | 国产爱啪啪 | 久久久久国产精品免费 | 亚洲欧美日韩国产一区二区精品 | 国产成人精品久久一区二区三区 | 国产a国产片 | 国产成人精品一区二区视频 | 性感美女香蕉视频 | 国产精品三级一区二区 | 久草男人天堂 | 国产高清日韩 | 日本亚洲高清 | 国产成人综合日韩精品无 | 大陆老太xxxxxxxxhd | 亚洲精品一区二区久久 | 久久久久亚洲香蕉网 | 99视频免费看 | 激情丝袜美女视频二区 | 996久久国产精品线观看 | 三级黄色网址 | 久久狠狠一本精品综合网 | 国产一在线精品一区在线观看 | 欧美一级成人毛片影院 | 久久精品国产欧美日韩亚洲 | 亚洲好视频 | 成人高清毛片a | 九草视频 | 国产欧美日韩在线人成aaaa | 免看一级a毛片一片成人不卡 | 国内一区 | 亚洲欧美在线不卡 | 成人免费视频一区 | 各种偷拍盗摄视频在线观看 | 三级网站 | 日韩不卡一二三区 |