七、索引優化分析

来源:https://www.cnblogs.com/lee0527/archive/2020/01/27/12236130.html
-Advertisement-
Play Games

SQL性能下降的原因 查詢語句寫的不好 索引失效 關聯查詢太多 伺服器調優及各個參數的的設置(緩衝、線程數等等) 常見的JOIN查詢 1、SQL的執行順序 手寫的順序: 真正機器執行的順序: 2、七種join查詢 最後兩種語法mysql不支持,但是我們可以用union來聯合其他的查詢結果來拼湊出最終 ...


SQL性能下降的原因

  • 查詢語句寫的不好
  • 索引失效
  • 關聯查詢太多
  • 伺服器調優及各個參數的的設置(緩衝、線程數等等)

常見的JOIN查詢

1、SQL的執行順序

手寫的順序:

真正機器執行的順序:

2、七種join查詢

最後兩種語法mysql不支持,但是我們可以用union來聯合其他的查詢結果來拼湊出最終結果。

索引

1、什麼是索引?

MySQL官方對索引的定義為:索引(Index)是幫助MySQL高效獲取數據的數據結構。

也可以簡單理解為“排好序的快速查找數據結構”

數據本身之外,資料庫還維護著一個滿足特定查找演算法的數據結構,這些數據結構以某種方式指向數據,這樣就可以在這些數據結構的基礎上實現高級查找演算法,這種數據結構就是索引。

一般來說索引本身也很大,不可能全部存儲在記憶體中,因此所以往往以索引文件的形式存儲在磁碟上。

2、索引的優勢和劣勢

優勢

  • 提高了數據檢索的效率,降低了資料庫的IO成本
  • 降低了數據排序的成本,降低了CPU的消耗

劣勢

  • 實際上索引也是一張表,該表保存了主鍵與索引欄位,並指向實體表的記錄,所以索引列也是要占用空間的
  • 雖然索引大大的提高了查詢速度,但同時也會降低更新表的速度,因為進行更新表時,MySQL不僅要保存數據,還要保存一下索引文件每次更新添加了索引列的欄位,都會調整因為更新所帶來的鍵值變化後的索引信息

3、索引的分類

  • 單值索引:即一個索引只包含單個列,一個表可以有多個單值索引
  • 唯一索引:索引列的值必須唯一但允許有空值
  • 複合索引:即一個索引包含多個列

4、基本語法

  • 創建

    CREATE [UNIQUE] INDEX indexName ON table_name(columnname(length))

    ALTER table_name ADD [UNIQUE] INDEX indexName ON (columnname(length))

    如果時CHAR、VARCHAR類型,length可以小於欄位實際長度,如果是BLOB和TEXT類型,必須指定length

  • 刪除

    DROP INDEX [indexName] ON table_name

  • 查看

    SHOW INDEX FROM table_name

5、哪些情況需要創建索引?

  • 主鍵自動建立唯一索引
  • 頻繁作為查詢條件的欄位應該創建索引
  • 查詢中與其他表關聯的欄位,外鍵關係建立索引
  • 頻繁更新的欄位不合適創建索引
  • Where條件里用不到的欄位不創建索引
  • 在高併發下傾向創建組合索引
  • 查詢中排序的欄位,排序欄位若通過索引去訪問將大大提高排序速度
  • 查詢中統計或者分組的欄位

6、哪些情況不需要創建索引?

  • 表記錄太少
  • 經常增刪改的表
  • 如果某個數據列包含許多重覆的內容,為它建立索引就沒有太大的實際效果

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

-Advertisement-
Play Games
更多相關文章
  • 單例模式: 即在整個生命周期中,對於該對象的生產始終都是一個,不曾變化。 保證了一個類僅有一個實例,並提供一個訪問它的全局訪問點。 作用: 在要求線程安全的情況下,保證了類實例的唯一性,線程安全。 在不需要多實例存在時,保證了類實例的單一性。不浪費記憶體。 特點: 公有的方法獲取實例, 私有的構造方法 ...
  • 三大查找演算法 1.二分查找(Binary Search) 2.插值查找(InsertValue Search) 3.斐波那契查找(Fibonacci Search) ...
  • Map創建 創建Map: var map1 = {"first":"Dart",1:true,true:"2"}; 創建不可變Map: var map2 = const{"first":"Dart",1:true,true:"2"};構造創建:var map3 = new Map(); 常用操作 [ ...
  • 一、創建list 創建List : var list = [1,2,3,"Dart",true]; 創建不可變List : var list = const [1,2,3,"Dart",true]; 構造創建:var list3 = new List(); 二、常用操作 [],length,add( ...
  • execute(String sql) 可執行任何sql語句,但返回值是void,所以一般用於資料庫的新建、修改、刪除和數據表記錄的增刪改。 int update(String sql) int update(String sql, Object...args) 增刪改,args傳遞實參,返回受影響 ...
  • 3. 如果同時拿一個板塊股票的收市價和成交額 前一篇說到,用大盤指數,如恆生指數,上證,深證,這些重要的大盤指數來做Dataframe主鍵,那麼如果是同時拿一個板塊股票的收市價和成交額,可以怎樣操作呢。 在實際開發中,應該是簡單的數據結構,容易閱讀為主,所以Dataframe的multi index ...
  • 1.線程安全:當多個線程訪問一個對象時,如果不用考慮這些線程在運行時環境下的調度和交替執行,也不需要進行額外的同步,或者在調用方法進行任何其他的協調操作,調用這個對象的行為都可以獲得正確的結果,那這個對象就是線程安全的。 2.Java語言中的線程安全 根據線程安全的安全程度由強到弱來排序,我們可以把 ...
  • 2. 金融股票數據的另一個形態,怎樣在業務內部流動,同時怎樣避免錯誤 前一篇講解了股票的原始狀態,那麼在業務過程中,數據會變成怎樣的形態,來完成眾多奇奇怪怪的業務呢,以下將會解答。 首先,任何股票都有機會停市,退市。或者退市了再二次上市。 例子,阿裡爸爸(9988.HK)在港交所二次上市。 再例如, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...