婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL索引的基本語法

MySQL索引的基本語法

熱門標簽:臨沂做地圖標注 申請400電話電話價格 新鄉智能外呼系統好處 石家莊400電話辦理公司 宜賓全自動外呼系統廠家 地圖標注客戶付款 許昌外呼增值業務線路 咸陽防封電銷卡 廣東400企業電話申請流程

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

索引的分類

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

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

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

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

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

創建索引

#普通索引

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

#唯一索引

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

#主鍵索引

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

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

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

#查看索引

show index from student \G

這里用\G 代替分號結束符;可以格式化輸出數據信息。

#刪除索引

修改表的方式刪除索引

ALTER TABLE 表名 DROP INDEX 索引名;

刪除主鍵索引

ALTER TABLE 表名 DROP PRIMARY KEY;

索引列為一列時為單一索引;
多個列組合在一起創建的索引叫做聯合索引

什么情況下可以創建索引?

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

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

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

3.需要經常 GROUP BY 和 ORDER BY 的列

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

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

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

5.DISTINCT 字段需要創建索引

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

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

什么時候不需要創建索引?

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

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

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

3.字段中如果有大量重復數據,也不用創建索引,比如性別字段;

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

什么情況下索引失效?

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

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

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

4.索引列盡量設置為 NOT NULL 約束

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

以上就是MySQL索引的基本語法的詳細內容,更多關于MySQL索引語法的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MySql索引提高查詢速度常用方法代碼示例
  • MySQL索引失效的幾種情況匯總
  • 詳解MySQL 聚簇索引與非聚簇索引
  • Mysql索引性能優化問題解決方案
  • 導致MySQL索引失效的一些常見寫法總結
  • MySQL索引的各種類型
  • MySQL性能優化之如何高效正確的使用索引
  • Mysql之組合索引方法詳解
  • MySQL選錯索引的原因以及解決方案

標簽:北京 日照 合肥 鎮江 鷹潭 貴州 臺灣 阜新

巨人網絡通訊聲明:本文標題《MySQL索引的基本語法》,本文關鍵詞  MySQL,索引,的,基本,語法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL索引的基本語法》相關的同類信息!
  • 本頁收集關于MySQL索引的基本語法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 汶上县| 乌拉特中旗| 宁波市| 长丰县| 镇原县| 邛崃市| 宜都市| 武陟县| 崇州市| 尼玛县| 万安县| 西安市| 博野县| 陈巴尔虎旗| 田林县| 句容市| 将乐县| 长兴县| 永靖县| 凤山市| 剑川县| 武鸣县| 扶沟县| 土默特左旗| 托克逊县| 夏邑县| 龙海市| 桓仁| 库伦旗| 宣武区| 延长县| 隆德县| 布拖县| 富顺县| 桂东县| 搜索| 都昌县| 密云县| 灯塔市| 河东区| 区。|