論MySQL何時使用索引,何時不使用索引

来源:https://www.cnblogs.com/XiaKang/archive/2018/02/05/8419518.html
-Advertisement-
Play Games

索引: 使用索引可快速訪問資料庫表中的特定信息。索引是對資料庫表中一列或多列的值進行排序的一種結構,例如 employee 表的姓(name)列。如果要按姓查找特定職員,與必須搜索表中的所有行相比,索引會幫助您更快地獲得該信息。 索引是一個單獨的、物理的資料庫結構,它是某個表中一列或若幹列值的集合和 ...


索引:

使用索引可快速訪問資料庫表中的特定信息。索引是對資料庫表中一列或多列的值進行排序的一種結構,例如 employee 表的姓(name)列。如果要按姓查找特定職員,與必須搜索表中的所有行相比,索引會幫助您更快地獲得該信息。

索引是一個單獨的、物理的資料庫結構,它是某個表中一列或若幹列值的集合和相應的指向表中物理標識這些值的數據頁的邏輯指針清單。

索引提供指向存儲在表的指定列中的數據值的指針,然後根據您指定的排序順序對這些指針排序。資料庫使用索引的方式與您使用書籍中的索引的方式很相似:它搜索索引以找到特定值,然後順指針找到包含該值的行。

在資料庫關係圖中,您可以在選定表的“索引/鍵”屬性頁中創建、編輯或刪除每個索引類型。當保存索引所附加到的表,或保存該表所在的關係圖時,索引將保存在資料庫中。

註意:

並非所有的資料庫都以相同的方式使用索引。作為通用規則,只有當經常查詢索引列中的數據時,才需要在表上創建索引。索引占用磁碟空間,並且降低添 加、刪除和更新行的速度。在多數情況下,索引用於數據檢索的速度優勢大大超過它的不足之處。但是,如果應用程式非常頻繁地更新數據或磁碟空間有限,則可能 需要限制索引的數量。

可以基於資料庫表中的單列或多列創建索引。多列索引使您可以區分其中一列可能有相同值的行。

如果經常同時搜索兩列或多列或按兩列或多列排序時,索引也很有幫助。例如,如果經常在同一查詢中為姓和名兩列設置判據,那麼在這兩列上創建多列索引將很有意義。

確定索引的有效性:

  • 檢查查詢的 WHERE 和 JOIN 子句。在任一子句中包括的每一列都是索引可以選擇的對象。
  • 對新索引進行試驗以檢查它對運行查詢性能的影響。
  • 考慮已在表上創建的索引數量。最好避免在單個表上有很多索引。
  • 檢查已在表上創建的索引的定義。最好避免包含共用列的重疊索引。
  • 檢查某列中唯一數據值的數量,並將該數量與表中的行數進行比較。比較的結果就是該列的可選擇性,這有助於確定該列是否適合建立索引,如果適合,確定索引的類型。

 

MySQL何時使用索引

對一個鍵碼使用>, >=, =, <, <=, IF NULL和BETWEEN

  1. SELECT * FROM table_name WHERE key_part1=1 and key_part2 > 5; 
  2. SELECT * FROM table_name WHERE key_part1 IS NULL; 

當使用不以通配符開始的LIKE

  1. SELECT * FROM table_name WHERE key_part1 LIKE 'jani%' 

在進行聯結時從另一個表中提取行時

  1. SELECT * from t1,t2 where t1.col=t2.key_part 

找出指定索引的MAX()或MIN()值

  1. SELECT MIN(key_part2),MAX(key_part2) FROM table_name where key_part1=10 

一個鍵碼的首碼使用ORDER BY或GROUP BY

  1. SELECT * FROM foo ORDER BY key_part1,key_part2,key_part3 

在所有用在查詢中的列是鍵碼的一部分時間

  1. SELECT key_part3 FROM table_name WHERE key_part1=1 

MySQL何時不使用索引

如果MySQL能估計出它將可能比掃描整張表還要快時,則不使用索引。例如如果key_part1均勻分佈在1和100之間,下列查詢中使用索引就不是很好:

  1. SELECT * FROM table_name where key_part1 > 1 and key_part1 < 90 

如果使用HEAP表且不用=搜索所有鍵碼部分。

在HEAP表上使用ORDER BY。

如果不是用鍵碼第一部分

  1. SELECT * FROM table_name WHERE key_part2=1 

如果使用以一個通配符開始的LIKE

  1. SELECT * FROM table_name WHERE key_part1 LIKE '%jani%' 

搜索一個索引而在另一個索引上做ORDER BY

  1. SELECT * from table_name WHERE key_part1 = # ORDER BY key

 

增加註明:當查詢條件欄位相同時,使用OR範圍查詢索引可以執行,反之,索引失效。

    例如:

  1. SELECT * from table_name WHERE name= "A"  OR  name="B";(生效)
  2. SELECT * from table_name WHERE name= "A"  OR  sex="男";(失效)

誤區

  1.並不是在where條件常用的列上加上索引,一條語句只會走一個索引。

  2.在多列建立索引,查詢哪一列,都將發揮作用? 滿足左首碼要求

       聯合索引   index(A1,A2,A3)

       where A=1                        (生效)

    where A=1 and where A2=2               (生效)

    where A=1 and where A2=2 and where A3=3              (生效)

    where A=2        where A3=3                                               (不生效)

    where A=1 and where A2>2 and where A3=3                      (A1,A2生效,A3不生效)

    where A=1 and where A2 like 'jay%' and where A3=3          (A1,A2生效,A3不生效)

SQL優化

1.limit分頁優化

2.聚集索引:主鍵、沒有主鍵則定位第一個唯一索引(所有行的值非空)、如果上2個條件都不滿足則自動產生一個6位元組的id聚集索引。

3.輔助索引:包含鍵值的書簽,會存儲書簽數據。

4.count(*)   改為輔助索引。

 

轉自(https://www.cnblogs.com/crazylqy/p/4706228.html)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • lambda x: x * x,實際上就是 def f(x): retrun x * x 關鍵字lambda表示匿名函數,冒號前的x表示函數參數。 匿名函數只能有一個表達式,不用寫return,返回值就是該表達式的結果。 用匿名函數有個好處,因為函數沒有名字,不必擔心函數名衝突。此外,匿名函數也是一 ...
  • 微服務,通常都是用複雜的、大規模分散式集群來實現的。微服務構建在不同的軟體模塊上,這些軟體模塊,有可能是由不同的團隊開發、可能使用不同的編程語言來實現、有可能布在了幾千台伺服器,橫跨多個不同的數據中心。因此,就需要一些可以幫助理解系統行為、用於分析性能問題的工具。 API網關Ocelot 作為微服務 ...
  • 重寫 class 的 ToString() 來簡化獲取 enum 的 DescriptionAttribute 值 目錄 一、常見的 enum 類型版本 二、演變:class 版本的 enum 類型 三、演進:class 和 enum 兩者共存的版本 一、常見的 enum 類型版本 新建一個 Alg ...
  • 1. 前言 Fall Creators Update中提供了一個新得ColorPicker控制項,解決了以前選擇顏色只能用Combo Box的窘境。 2. 一個簡單的例子 如上所示,ColorPiker可以通過在光譜或色輪上拖動滑塊,或者在RGB/HSV及十六進位的TextBox中直接輸入顏色的數值改 ...
  • 一開始,思路是這樣的: 遺憾的是,將會拋出一個異常: 修改後的實現方式: 或者 : 最後附上SqlHelper: static class SqlHelper { private static readonly string ConnectionString = ConfigurationManag ...
  • ———————————————————————————————————————————————————————————————————————— QQ 是一款熱門的即時通信(IM)類工具,在安裝時刻會向系統分區的 \..\windows\system32\drivers 路徑下生成兩個驅動程式文件: ...
  • Shell 變數 定義變數時,變數名不加美元符號($,PHP語言中變數需要),如: 註意,變數名和等號之間不能有空格,這可能和你熟悉的所有編程語言都不一樣。同時,變數名的命名須遵循如下規則: 首個字元必須為字母(a z,A Z)。 中間不能有空格,可以使用下劃線(_)。 不能使用標點符號。 不能使用 ...
  • 大多數Windows用戶,右鍵中預設新建的文件格式就那麼幾種。這可能對我們愛折騰或者特殊要求的人員來說可能有點不方便,比如說要創建個 .reg .bat .vbs等格式的文件,就需要新建個文本文件修改尾碼為或者是通過對應軟體保存為 .reg .bat .vbs等。是不是有點麻煩喲,可不可以在右鍵中的 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...