MySQL中的索引、左連接、右連接、join、sql執行順序

来源:https://www.cnblogs.com/exce-ben/archive/2020/02/27/12370202.html
-Advertisement-
Play Games

邏輯架構: 1、連接層 2、服務層 3、引擎層(插拔式) 4、存儲層 存儲引擎: 常用的有:MyISAM、InnoDB 查看命令:show variables like '%storage_engine%'; 索引:【單值、複合】 創建索引:create index idx_user_name(索引 ...


邏輯架構:

  1、連接層

  2、服務層

  3、引擎層(插拔式)

  4、存儲層

存儲引擎:

  常用的有:MyISAM、InnoDB

  查看命令:show variables like '%storage_engine%';

索引:【單值、複合】

 創建索引:create index idx_user_name(索引名字) on user(表名) (name)(欄位名)

 刪除索引:drop index  idx_user_name(索引名字)on user(表名) 

CREATE INDEX idx_article_ccv ON article(category_id,comments,views);

DROP INDEX idx_article_ccv ON article;

 

 

 

  定義:索引是一種數據結構(幫助MySQL高效的獲取數據)

  目的:提高查詢效率,可以類比字典【可以理解為排好序的快速查找數據結構】

 優勢:提高數據檢索效率,降低資料庫的iO成本;

 劣勢:實際上索引也是一種表,它保存的索引欄位,是需要占空間的;會降低更新表速度,因為更新表時,MySQL不僅要保存數據還要保存索引文件每次更新添加了索引的欄位

 

  分類:

    

    

 原理:二分查找,類似猜數字游戲【結構:B-TREE(Java主要)、hash、R-TREE】

 什麼時候該建索引:

  如:where後面需要被查詢的欄位

什麼時候不該建索引:

  1、表記錄太少

  2、經常增刪改的表或欄位

  3、數據重覆切分佈平均的欄位【如果某個數據列包含許多重覆的內容,為它建立索引就沒有很麽實際的效果】

常見的join查詢:

  一、SQL執行順序

    1 FROM <left_table>

    2 ON <join_condition>

    3 <join_type>JOIN<right_table>

    4 WHERE <where_condition>

    5 GROUP BY <group_by_list>

    6 HAVING <having_condition>

    7 SELECT

    8 DISTINCT<select_list>

    9 ORDER BY <order_by_condition>

    10 LIMIT <limit_number>

 

 

  二、7種join圖

 

 


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

-Advertisement-
Play Games
更多相關文章
  • Everspin 是設計,製造和商業銷售離散和嵌入式磁阻RAM(MRAM)和自旋傳遞扭矩MRAM(STT-MRAM)的全球領導者,其市場和應用領域涉及數據持久性和完整性,低延遲和安全性至關重要。Everspin在數據中心,雲存儲,能源,工業,汽車和運輸市場中部署了超過1.2億個MRAM和STT-MR ...
  • 隨著單塊磁碟在數據安全、性能、容量上呈現出的局限,磁碟陣列(Redundant Arrays of Inexpensive/Independent Disks,RAID)出現了,RAID把多塊獨立的磁碟按不同的方式組合起來,形成一個磁碟組,以獲得比單塊磁碟更高的數據安全、性能、容量。 一. 常見的R ...
  • 一 磁碟物理結構 (1) 碟片:硬碟的盤體由多個碟片疊在一起構成。 在硬碟出廠時,由硬碟生產商完成了低級格式化(物理格式化),作用是將空白的碟片(Platter)劃分為一個個同圓心、不同半徑的磁軌(Track),還將磁軌劃分為若幹個扇區(Sector),每個扇區可存儲128×2的N次方(N=0.1. ...
  • Samba伺服器安裝和配置 1:安裝Samba伺服器軟體包 [root@localhost ~]# rpm -qa | grep samba [root@localhost ~]# yum -y install samba [root@localhost ~]# yum -y install sam ...
  • / 本文為個人學習記錄,如有錯誤,歡迎指正。 本文參考資料: "https://blog.csdn.net/qq_28992301/article/details/52410587" "https://blog.csdn.net/hanp_linux/article/details/79037610 ...
  • Mysql:MySQL數據管理 外鍵管理 外鍵概念 如果公共關鍵字在一個關係中是主關鍵字,那麼這個公共關鍵字被稱為另一個關係的外鍵。由此可見,外鍵表示了兩個關係之間的相關聯繫。以另一個關係的外鍵作主關鍵字的表被稱為 主表 ,具有此外鍵的表被稱為主表的 從表 。 在實際操作中,將一個表的值放入第二個表 ...
  • SQLyog安裝教程 一、軟體下載 為了更好的學習,我們需要可視化界面,而不僅僅是通過命令行黑視窗管理資料庫。SQLyog 就是一個快速而簡潔的圖形化管理MYSQL資料庫的工具。 SQLyog12.08下載地址: 鏈接:https://pan.baidu.com/s/1iU6NtsthYwgx02z ...
  • 一、用法及定義: explain為sql的執行計劃、在sql前面加上explain關鍵字即可 如:explain select * from tbl_emp; 名詞解釋: id:【操作表的順序】 1.id相同,表的執行順序從上往下依次執行 2.id不同,id越大的越先執行 3.id相同和不同的一起, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...