MySQL速記小冊(1)

1

【Q】:Mysql中的數據排序是怎么實現的?

【A】:

  1. 排序過程中如果字段有索引,則利用索引排序。反之使用文件排序。在文件排序中,如果數據量少則在內存中排序,使用單路排序或雙路排序。如果數據量大則利于磁盤文件進行外部排序,一般是歸并排序。

2

【Q】:Mysql的Chang Buffer是什么?

【A】:

  1. Chang Buffer是Mysql InnoDB存儲引擎的一個機制,用于暫存對二級索引的刪除和更新操作的變更,而不是立刻執行這些操作,隨后,當InnoDB進行合適的條件時(如頁被讀取或Flush操作),會將這些變更寫入到二級索引中。
  2. 作用:
    1. 提高寫入性能,提高對二級索引的變更緩存,可以減少對磁盤的頻繁寫入,提升插入和更新操作的性能。
    2. 批量處理,Chang Buffer 可以在后續的操作中批量處理這些變更,減少了隨機寫入的開銷。

3

【Q】:詳細描述一下一條SQL語句在MySQL的執行過程

【A】:

  1. 先通過連接器校驗權限。
  2. 再利用分析器進行SQL語句的詞法分析和語法分析,構建解析樹。
  3. 使用優化器選擇合適的索引和表連接順序,最終選擇一個最佳的執行計劃。

4

【Q】:Mysql主要的存儲引擎包括:

【A】:

  1. InnoDB:支持事務 ,行級鎖和外鍵。提供高并發性能,適用于高負載的OLTP應用。數據以聚集索引的方式存儲,提高檢索效率。
  2. MyISAM:不支持事務和外鍵,適用表級鎖。適合讀取多,更新少的場景,如數據倉庫。具有較高的讀性能和較快的表級鎖定
  3. MEMORY和NDB和ARCHIVE。

5

【Q】:Mysql的索引類型有什么?

【A】:

  1. 從數據結構角度來看,Mysql索引可以分為以下幾類:
    1. B+樹索引
    2. 哈希索引
    3. 倒排索引(即全文索引 Full-Text)
    4. R-樹索引(多維空間樹)
  1. 從常見的基于InnoDB B+樹索引角度來看,可以分為:
    1. 聚簇索引
    2. 非聚簇索引
  1. 索引性質角度來看,普通索引,主鍵索引,聯合索引,唯一索引,全文索引,空間索引

6

【Q】:InooDB 引擎中的聚簇索索引和非聚簇索引區別

【A】:

  1. 聚簇索引
    1. 索引葉子節點存儲的是數據行,可以直接訪問完整數據。
    2. 每一個表只能有一個聚簇索引,通常是主鍵索引,適合訪問查詢和排序
  1. 非聚簇索引
    1. 索引葉子節點存儲的是數據行的主鍵和對應的索引列,需通過主鍵才能訪問完整的數據行。
    2. 一個表可以有多個非聚簇索引,適用于快速查找特定列的數據。

7

【Q】:MySQL里面的回表是什么?

【A】:

  1. 回表是指在使用二級索引(非聚簇索引)作為進行查詢時,由于二級索引中只存儲了索引字段的值和對應的主鍵值,無法獲得其他數據。如果要查詢數據行中的其他數據,需要根據主鍵去聚簇索引中查找實際的數據行,這個過程被稱為回表。

8

【Q】:索引的最左前綴匹配原則是什么?

【A】:

  1. Mysql索引的最左前匹配原則是指在使用聯合索引時,查詢條件必須從索引條件的最左側開始匹配。如果一個聯合索引包含多個列,查詢條件必須包含第一列的條件,然后是第二列,以此類推。
  2. 底層原理:因為聯合索引在B+樹中的排序方式遵循“從左到右”的順序,列如聯合索引(frist_name,last_name, age)會按照此順序在B+樹中進行排序。
  3. 組合索引能從左到右依次高效匹配,跳過最左側字段會導致無法利用該索引。

9

【Q】:Mysq覆蓋l索引是什么?

【A】:

  1. Mysql覆蓋索引是指二級索引中包含了查詢所需的所有字段,從而使查詢可以僅通過訪問二級索引而不需要訪問實際的表數據(主鍵索引)。

10

【Q】:索引下推是什么?

【A】:

  1. 索引下推是一種減少回表查詢,提高查詢效率的技術。允許Mysql在使用索引查找數據時,將部分查找條件下推到存儲引擎層過濾,從而減少需要從表中讀取的數據行,減少IO(本應該由service做的操作交給了存儲引擎層操作,因此叫做下推)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/98463.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/98463.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/98463.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

20250904 10:45_排查10.1.3.35新QMS系統RMAN備份失敗問題(優化腳本里的環境配置,增加了check_oracle_env 函數)

一、RMAN備份失敗日志如下 [2025-09-04 04:00:01] 備份腳本啟動 [2025-09-04 04:00:01] 開始 RMAN 備份 CDB: ORCLCDB Message file RMAN<lang>.msb not found Verify that ORACLE_HOME is set properly [2025-09-04 04:00:01] RMAN 備份失敗! 二、原備份腳本存檔…

Vue3源碼reactivity響應式篇之EffectScope

概述 EffectScope是Vue3中一個響應式系統的輔助類&#xff0c;用于管理副作用&#xff08;effect&#xff09;的作用域。它可以幫助我們更好地組織和管理多個effect&#xff0c;便于一起停止或暫停以及恢復&#xff0c;避免了全局狀態的污染和管理的復雜性。 每一個vue組件的實…

MySQL 日志全解析:Binlog/Redo/Undo 等 5 類關鍵日志的配置、作用與最佳實踐

1 二進制日志&#xff08;Binlog&#xff09;&#xff1a;配置與核心作用 Binlog 是 MySQL 中跨存儲引擎的核心日志&#xff0c;記錄所有數據修改操作&#xff0c;主要用于主從復制、數據備份恢復與跨庫遷移。 1.1 Binlog 核心操作 開啟 Binlog 若需開啟 Binlog&#xff0c;需在…

springboot 之 HTML與圖片生成 (2)

前言 之前寫了一篇html轉圖片的 文章&#xff0c;使用中文時會出現亂碼情況&#xff0c;后來又從網上找了下信息&#xff0c;這篇主要介紹下另一個轉換庫。 依賴 <!-- 用于將html轉圖片--><dependency><groupId>gui.ava</groupId><artifactId>…

計算機組成原理:計算機的分類

&#x1f4cc;目錄&#x1f5a5;? 計算機組成原理&#xff1a;計算機的分類——從架構到應用的全景梳理一、按處理數據類型分類&#xff1a;從“數字”到“混合”的演進&#xff08;一&#xff09;數字計算機&#xff1a;離散數據的“精準管家”1. 核心原理2. 關鍵優勢3. 典型…

數據結構——單向循環鏈表代碼(補充)

在此前的文章中&#xff08;鏈接如下&#xff09;&#xff0c;只有單向鏈表的代碼&#xff0c;接下來我們來寫單向循環鏈表&#xff0c;并用其實現一個簡單的學生信息鏈表https://blog.csdn.net/2301_80406299/article/details/151157051?spm1011.2415.3001.10575&sharefr…

【Python自動化】 21.2 Pandas 讀取 Excel 時的 dtype 參數完全指南

一、dtype 參數概述 dtype 參數用于指定列的數據類型&#xff0c;在讀取 Excel 時非常重要&#xff0c;可以&#xff1a; 提高內存效率避免自動類型推斷錯誤確保數據一致性提升讀取性能 二、基本用法 1. 基礎語法 import pandas as pd# 指定列數據類型 df pd.read_excel(data.…

gtest全局套件的測試使用

gtest全局套件的測試使用 #include <iostream> #include "gtest/gtest.h" #include <unordered_map>class MyEnvironment: public testing::Environment {public:virtual void SetUp() override{std::cout<<"單元測試前的環境初始化&#xff…

【系統分析師】第7章-基礎知識:軟件工程(核心總結)

更多內容請見: 備考系統分析師-專欄介紹和目錄 文章目錄 一、軟件工程的基本概念 1.1 定義與意義 1.2 軟件工程的基本原則 1.3 核心定義與邊界 1.4 四大核心原則 1.5 三大核心目標 二、軟件生命周期 2.1 定義與階段劃分 2.2 軟件生命周期模型 三、軟件開發方法 3.1 結構化方法…

量化基金從小白到大師 - 金融數據獲取大全:從免費API到Tick級數據實戰指南

量化基金從小白到大師 - 金融數據獲取大全&#xff1a;從免費API到Tick級數據實戰指南 各位&#xff0c;今天咱們要啃一塊硬骨頭——金融數據獲取。別看這話題基礎&#xff0c;它可是整個量化大廈的地基&#xff0c;地基不穩&#xff0c;再牛的策略都得塌房。我見過太多人&…

構建一個“會思考”的房地產數據獲取腳本

—— 跨界思維&#xff1a;從認知自適應到房源信息監測 一、認知科學視角&#xff1a;什么是“會思考” 在心理學與認知科學中&#xff0c;所謂“會思考”&#xff0c;并不是指抽象的哲學推理&#xff0c;而是指個體能在復雜環境中不斷調整行動策略。 比如&#xff0c;出行時如…

JavaScript的庫簡介

JavaScript擁有豐富的庫生態系統,類似于Python的requests、numpy或C++的Boost。這些庫分為兩大類:前端庫(如React、Vue)和后端/工具庫(如Lodash、Axios)。以下是幾個核心庫的介紹與用法示例。 常用JavaScript庫分類 前端UI庫 React:Facebook開發的組件化庫,用于構建用…

【無GGuF版本】如何在Colab下T4運行gpt-oss 20B

OpenAI發布了gpt-oss 120B和20B版本。這兩個模型均采用Apache 2.0許可證。 特別說明的是&#xff0c;gpt-oss-20b專為低延遲及本地化/專業化場景設計&#xff08;210億總參數&#xff0c;36億活躍參數&#xff09;。 由于模型采用原生MXFP4量化訓練&#xff0c;使得20B版本即…

LeetCode - LCR 179. 查找總價格為目標值的兩個商品

題目 https://leetcode.cn/problems/he-wei-sde-liang-ge-shu-zi-lcof/submissions/660817798/ 思路 解法1是暴力解法&#xff0c;從第一個開始和后面的相加 暴力枚舉慢就慢在&#xff0c;這個遞增數組是排序好的數組&#xff0c;已經是有序的&#xff0c;暴力解法沒有利用這…

UI自動化測試Python + Selenium + WinAppDriver( Windows 桌面應用)落地(一)環境搭建

最近公司要求為Windows 端桌面應用進行UI自動化測試,之前都是針對web端進行的UI自動化測試或者在早期使用的是QTP(Quick Test Professional)做PC端的UI自動化測試,而基于"經費"緊張,優先選擇開源的工具,所以選擇了selenium + WinAppDriver來實現。 首先,整理…

基于OpenCV的銀行卡號識別系統:從原理到實現

引言在現代金融科技應用中&#xff0c;銀行卡號的自動識別是一項重要技術。本文將詳細介紹如何使用Python和OpenCV庫構建一個完整的銀行卡號識別系統。該系統能夠從銀行卡圖像中提取卡號信息&#xff0c;并根據卡號首數字判斷銀行卡類型。技術棧?OpenCV: 計算機視覺庫&#xf…

概率論第三講——多維隨機變量及其分布

文章目錄考綱n維隨機變量及其分布函數聯合分布函數邊緣分布函數二維離散型隨機變量的概率分布、邊緣分布和條件分布二維連續型隨機變量的概率密度、邊緣概率密度和條件概率密度常見的二位分布二維均勻分布二維正態分布隨機變量的相互獨立性概念相互獨立的充要條件相互獨立的性質…

純軟件實現電腦屏幕錄制/存儲到硬盤錄像機/onvif模擬器/onvif虛擬監控/綠色版雙擊開箱即用

一、前言說明 在銀行、超市、考試中心、工控系統、網課教學、居家辦公等場景中&#xff0c;傳統監控攝像頭難以清晰錄制電腦屏幕內容&#xff0c;導致關鍵操作無法有效追溯。為解決這一難題&#xff0c;我們推出了一套純軟件實現的電子屏幕監控方案&#xff0c;徹底取代依賴硬…

【算法--鏈表】86.分割鏈表--通俗講解

一、題目是啥?一句話說清 給你一個鏈表和一個值 x,把鏈表分成兩部分:所有小于 x 的節點都放在大于或等于 x 的節點之前,并且保持節點原來的相對順序。 示例: 輸入:head = [1,4,3,2,5,2], x = 3 輸出:[1,2,2,4,3,5](所有小于3的節點1、2、2都在大于等于3的節點4、3、5…

707, 設計鏈表, LinkedList, 單鏈表, Dummy Head, C++

目錄 題意速覽解題思路與設計要點C 代碼實現&#xff08;單鏈表 虛擬頭結點&#xff09;時間復雜度與空間復雜度常見坑位與邊界用例對比&#xff1a;雙鏈表如何優化單元測試樣例&#xff08;可直接粘貼運行&#xff09;總結 題意速覽 設計一個支持如下操作的鏈表&#xff1a…