chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MySQL索引的使用問題

數(shù)據(jù)分析與開發(fā) ? 來(lái)源:數(shù)據(jù)分析與開 ? 作者:Harvey ? 2021-01-06 16:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、前言

在MySQL中進(jìn)行SQL優(yōu)化的時(shí)候,經(jīng)常會(huì)在一些情況下,對(duì)MySQL能否利用索引有一些迷惑。譬如:1、MySQL 在遇到范圍查詢條件的時(shí)候就停止匹配了,那么到底是哪些范圍條件?2、MySQL 在LIKE進(jìn)行模糊匹配的時(shí)候又是如何利用索引的呢?3、MySQL 到底在怎么樣的情況下能夠利用索引進(jìn)行排序?今天,我將會(huì)用一個(gè)模型,把這些問題都一一解答,讓你對(duì)MySQL索引的使用不再畏懼。

二、知識(shí)補(bǔ)充

EXPLAIN執(zhí)行計(jì)劃中有一列 key_len 用于表示本次查詢中,所選擇的索引長(zhǎng)度有多少字節(jié),通常我們可借此判斷聯(lián)合索引有多少列被選擇了。在這里 key_len 大小的計(jì)算規(guī)則是:

一般地,key_len 等于索引列類型字節(jié)長(zhǎng)度,例如int類型為4 bytes,bigint為8 bytes;

如果是字符串類型,還需要同時(shí)考慮字符集因素,例如:CHAR(30) UTF8則key_len至少是90 bytes;

若該列類型定義時(shí)允許NULL,其key_len還需要再加 1 bytes;

若該列類型為變長(zhǎng)類型,例如 VARCHAR(TEXTBLOB不允許整列創(chuàng)建索引,如果創(chuàng)建部分索引也被視為動(dòng)態(tài)列類型),其key_len還需要再加 2 bytes;

三、哪些條件能用到索引

首先非常感謝登博,給了我一個(gè)很好的啟發(fā),我通過他的文章_,然后結(jié)合自己的理解,制作出了這幅圖:

乍一看,是不是很暈,不急,我們慢慢來(lái)看圖中一共分了三個(gè)部分:

1、Index Key :MySQL是用來(lái)確定掃描的數(shù)據(jù)范圍,實(shí)際就是可以利用到的MySQL索引部分,體現(xiàn)在Key Length。

2、Index Filter:MySQL用來(lái)確定哪些數(shù)據(jù)是可以用索引去過濾,在啟用ICP后,可以用上索引的部分。

3、Table Filter:MySQL無(wú)法用索引過濾,回表取回行數(shù)據(jù)后,到server層進(jìn)行數(shù)據(jù)過濾。下面我們細(xì)細(xì)展開。Index Key是用來(lái)確定MySQL的一個(gè)掃描范圍,分為上邊界和下邊界。MySQL利用=、》=、》 來(lái)確定下邊界(first key),利用最左原則,首先判斷第一個(gè)索引鍵值在where條件中是否存在,如果存在,則判斷比較符號(hào),如果為(=,》=)中的一種,加入下邊界的界定,然后繼續(xù)判斷下一個(gè)索引鍵,如果存在且是(》),則將該鍵值加入到下邊界的界定,停止匹配下一個(gè)索引鍵;如果不存在,直接停止下邊界匹配。


		exp:idx_c1_c2_c3(c1,c2,c3)where c1>=1 and c2>2 and c3=1--> first key (c1,c2)--> c1為 '>=' ,加入下邊界界定,繼續(xù)匹配下一個(gè)-->c2 為 '>',加入下邊界界定,停止匹配上邊界(last key)和下邊界(first key)類似,首先判斷是否是否是(=,<=)中的一種,如果是,加入界定,繼續(xù)下一個(gè)索引鍵值匹配,如果是(<),加入界定,停止匹配

		exp:idx_c1_c2_c3(c1,c2,c3)where c1<=1 and c2=2 and c3<3--> last key (c1,c2,c3)--> c1為 '<=',加入上邊界界定,繼續(xù)匹配下一個(gè)--> c2為 '='加入上邊界界定,繼續(xù)匹配下一個(gè)--> c3 為 '<',加入上邊界界定,停止匹配

注:這里簡(jiǎn)單的記憶是,如果比較符號(hào)中包含‘=’號(hào),‘》=’也是包含‘=’,那么該索引鍵是可以被利用的,可以繼續(xù)匹配后面的索引鍵值;如果不存在‘=’,也就是‘》’,‘《’,這兩個(gè),后面的索引鍵值就無(wú)法匹配了。同時(shí),上下邊界是不可以混用的,哪個(gè)邊界能利用索引的的鍵值多,就是最終能夠利用索引鍵值的個(gè)數(shù)。

Index Filter

字面理解就是可以用索引去過濾。也就是字段在索引鍵值中,但是無(wú)法用去確定Index Key的部分。


		exp:idex_c1_c2_c3where c1>=1 and c2<=2 and c3 =1index key --> c1index filter--> c2 c3

這里為什么index key 只是c1呢?因?yàn)閏2 是用來(lái)確定上邊界的,但是上邊界的c1沒有出現(xiàn)(《=,=),而下邊界中,c1是》=,c2沒有出現(xiàn),因此index key 只有c1字段。c2,c3 都出現(xiàn)在索引中,被當(dāng)做index filter.

Table Filter

無(wú)法利用索引完成過濾,就只能用table filter。此時(shí)引擎層會(huì)將行數(shù)據(jù)返回到server層,然后server層進(jìn)行table filter。

四、Between 和Like 的處理

那么如果查詢中存在between 和like,MySQL是如何進(jìn)行處理的呢?

Between

where c1 between ‘a(chǎn)’ and ‘b’ 等價(jià)于 where c1》=‘a(chǎn)’ and c1 《=‘b’,所以進(jìn)行相應(yīng)的替換,然后帶入上層模型,確定上下邊界即可

Like

首先需要確認(rèn)的是%不能是最在最左側(cè),where c1 like ‘%a’ 這樣的查詢是無(wú)法利用索引的,因?yàn)樗饕钠ヅ湫枰献钭笄熬Y原則where c1 like ‘a(chǎn)%’ 其實(shí)等價(jià)于 where c1》=‘a(chǎn)’ and c1《‘b’ 大家可以仔細(xì)思考下。

五、索引的排序

在數(shù)據(jù)庫(kù)中,如果無(wú)法利用索引完成排序,隨著過濾數(shù)據(jù)的數(shù)據(jù)量的上升,排序的成本會(huì)越來(lái)越大,即使是采用了limit,但是數(shù)據(jù)庫(kù)是會(huì)選擇將結(jié)果集進(jìn)行全部排序,再取排序后的limit 記錄,而且MySQL 針對(duì)可以用索引完成排序的limit 有優(yōu)化,更能減少成本。

Make sure it uses index It is very important to have ORDER BY with LIMIT executed without scanning and sorting full result set, so it is important for it to use index – in this case index range scan will be started and query execution stopped as soon as soon as required amount of rows generated.

		CREATE TABLE `t1` ( `id` int(11) NOT NULL AUTO_INCREMENT, `c1` int(11) NOT NULL DEFAULT '0', `c2` int(11) NOT NULL DEFAULT '0', `c3` int(11) NOT NULL DEFAULT '0', `c4` int(11) NOT NULL DEFAULT '0', `c5` int(11) NOT NULL DEFAULT '0', PRIMARY KEY (`id`), KEY `idx_c1_c2_c3` (`c1`,`c2`,`c3`)) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8mb4  select * from t1;+----+----+----+----+----+----+| id | c1 | c2 | c3 | c4 | c5 |+----+----+----+----+----+----+| 1 | 3 | 3 | 2 | 0 | 0 || 2 | 2 | 4 | 5 | 0 | 0 || 3 | 3 | 2 | 4 | 0 | 0 || 4 | 1 | 3 | 2 | 0 | 0 || 5 | 1 | 3 | 3 | 0 | 0 || 6 | 2 | 3 | 5 | 0 | 0 || 7 | 3 | 2 | 6 | 0 | 0 |+----+----+----+----+----+----+7 rows in set (0.00 sec)  select c1,c2,c3 from t1;+----+----+----+| c1 | c2 | c3 |+----+----+----+| 1 | 3 | 2 || 1 | 3 | 3 || 2 | 3 | 5 || 2 | 4 | 5 || 3 | 2 | 4 || 3 | 2 | 6 || 3 | 3 | 2 |+----+----+----+7 rows in set (0.00 sec)

	

存在一張表,c1,c2,c3上面有索引,select c1,c2,c3 from t1; 查詢走的是索引全掃描,因此呈現(xiàn)的數(shù)據(jù)相當(dāng)于在沒有索引的情況下select c1,c2,c3 from t1 order by c1,c2,c3; 的結(jié)果。因此,索引的有序性規(guī)則是怎么樣的呢?c1=3 —》 c2 有序,c3 無(wú)序 c1=3,c2=2 — 》 c3 有序 c1 in(1,2) —》 c2 無(wú)序 ,c3 無(wú)序

有個(gè)小規(guī)律,idx_c1_c2_c3,那么如何確定某個(gè)字段是有序的呢?c1 在索引的最前面,肯定是有序的,c2在第二個(gè)位置,只有在c1 唯一確定一個(gè)值的時(shí)候,c2才是有序的,如果c1有多個(gè)值,那么c2 將不一定有序,同理,c3也是類似

六、小結(jié)

針對(duì)MySQL索引,我這邊只是提到了在單表查詢情況下的模型,通過這篇文章,想必大家應(yīng)該了解到MySQL大部分情況下是如何利用索引的。

責(zé)任編輯:xj

原文標(biāo)題:MySQL 的索引是如何工作的?10 分鐘講清楚!

文章出處:【微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    897

    瀏覽量

    29196
  • 索引
    +關(guān)注

    關(guān)注

    0

    文章

    60

    瀏覽量

    10756

原文標(biāo)題:MySQL 的索引是如何工作的?10 分鐘講清楚!

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Hudi系列:Hudi核心概念之索引(Indexs)

    上的Instant action操作類型 ?1.4 時(shí)間線上State狀態(tài)類型 ?1.5 時(shí)間線官網(wǎng)實(shí)例 ?二. 文件布局 ?三. 索引 3.1 簡(jiǎn)介 3.2 對(duì)比其它(Hive)沒有索引的區(qū)別 3.2
    的頭像 發(fā)表于 10-21 09:47 ?178次閱讀
    Hudi系列:Hudi核心概念之<b class='flag-5'>索引</b>(Indexs)

    MySQL慢查詢終極優(yōu)化指南

    作為一名在生產(chǎn)環(huán)境摸爬滾打多年的運(yùn)維工程師,我見過太多因?yàn)槁樵儗?dǎo)致的線上故障。今天分享一套經(jīng)過實(shí)戰(zhàn)檢驗(yàn)的MySQL慢查詢分析與索引優(yōu)化方法論,幫你徹底解決數(shù)據(jù)庫(kù)性能瓶頸。
    的頭像 發(fā)表于 08-13 15:55 ?641次閱讀

    MySQL 8.0性能優(yōu)化實(shí)戰(zhàn)指南

    作為一名運(yùn)維工程師,MySQL數(shù)據(jù)庫(kù)優(yōu)化是我們?nèi)粘9ぷ髦凶罹咛魬?zhàn)性的任務(wù)之一。MySQL 8.0作為當(dāng)前主流版本,在性能、安全性和功能上都有了顯著提升,但如何充分發(fā)揮其潛力,仍需要我們掌握正確的優(yōu)化策略。
    的頭像 發(fā)表于 07-24 11:48 ?524次閱讀

    MySQL數(shù)據(jù)備份與恢復(fù)策略

    數(shù)據(jù)是企業(yè)的核心資產(chǎn),MySQL作為主流的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),其數(shù)據(jù)的安全性和可靠性至關(guān)重要。本文將深入探討MySQL的數(shù)據(jù)備份策略、常用備份工具以及數(shù)據(jù)恢復(fù)的最佳實(shí)踐,幫助運(yùn)維工程師構(gòu)建完善的數(shù)據(jù)保護(hù)體系。
    的頭像 發(fā)表于 07-14 11:11 ?458次閱讀

    企業(yè)級(jí)MySQL數(shù)據(jù)庫(kù)管理指南

    在當(dāng)今數(shù)字化時(shí)代,MySQL作為全球最受歡迎的開源關(guān)系型數(shù)據(jù)庫(kù),承載著企業(yè)核心業(yè)務(wù)數(shù)據(jù)的存儲(chǔ)與處理。作為數(shù)據(jù)庫(kù)管理員(DBA),掌握MySQL的企業(yè)級(jí)部署、優(yōu)化、維護(hù)技能至關(guān)重要。本文將從實(shí)戰(zhàn)角度出發(fā),系統(tǒng)闡述MySQL在企業(yè)環(huán)
    的頭像 發(fā)表于 07-09 09:50 ?497次閱讀

    除了增刪改查你對(duì)MySQL還了解多少

    我們都知道MySQL服務(wù)器的默認(rèn)端口為3306,之后就在這個(gè)端口號(hào)上等待客戶端進(jìn)程進(jìn)行連接(MySQL服務(wù)器會(huì)默認(rèn)監(jiān)聽3306端口)。
    的頭像 發(fā)表于 04-14 17:20 ?505次閱讀

    從Delphi、C++ Builder和Lazarus連接到MySQL數(shù)據(jù)庫(kù)

    ? 從 Delphi、C++ Builder 和 Lazarus 連接到 MySQL 數(shù)據(jù)庫(kù) MySQL 數(shù)據(jù)訪問組件(MyDAC)是一個(gè)組件庫(kù),提供從 Delphi 和 C++ Builder
    的頭像 發(fā)表于 01-20 13:47 ?1301次閱讀
    從Delphi、C++ Builder和Lazarus連接到<b class='flag-5'>MySQL</b>數(shù)據(jù)庫(kù)

    使用插件將Excel連接到MySQL/MariaDB

    使用插件將 Excel 連接到 MySQL/MariaDB 適用于 MySQL 的 Devart Excel 插件允許您將 Microsoft Excel 連接到 MySQL 或 MariaDB
    的頭像 發(fā)表于 01-20 12:38 ?1119次閱讀
    使用插件將Excel連接到<b class='flag-5'>MySQL</b>/MariaDB

    適用于MySQL和MariaDB的Python連接器:可靠的MySQL數(shù)據(jù)連接器和數(shù)據(jù)庫(kù)

    適用于 MySQL 和 MariaDB 的 Python 連接器 Python Connector for MySQL 是一種可靠的連接解決方案,用于從 Python 應(yīng)用程序訪問 MySQL
    的頭像 發(fā)表于 01-17 12:18 ?838次閱讀
    適用于<b class='flag-5'>MySQL</b>和MariaDB的Python連接器:可靠的<b class='flag-5'>MySQL</b>數(shù)據(jù)連接器和數(shù)據(jù)庫(kù)

    適用于MySQL和MariaDB的.NET連接器

    支持 ORM 的適用于 MySQL 和 MariaDB 的 .NET 連接器 dotConnect for MySQL 是一種高性能 ADO.NET 數(shù)據(jù)提供程序,可在開發(fā) MySQL 的應(yīng)用程序
    的頭像 發(fā)表于 01-16 14:17 ?787次閱讀
    適用于<b class='flag-5'>MySQL</b>和MariaDB的.NET連接器

    MySQL數(shù)據(jù)庫(kù)的安裝

    MySQL數(shù)據(jù)庫(kù)的安裝 【一】各種數(shù)據(jù)庫(kù)的端口 MySQL :3306 Redis :6379 MongoDB :27017 Django :8000 flask :5000 【二】MySQL 介紹
    的頭像 發(fā)表于 01-14 11:25 ?846次閱讀
    <b class='flag-5'>MySQL</b>數(shù)據(jù)庫(kù)的安裝

    創(chuàng)建唯一索引的SQL命令和技巧

    在創(chuàng)建唯一索引時(shí),以下是一些SQL命令和技巧,可以幫助優(yōu)化性能: 使用合適的索引類型:對(duì)于需要保證唯一性的列,使用UNIQUE索引來(lái)避免重復(fù)數(shù)據(jù)的插入。 這可以確保列中的值是唯一的,同時(shí)提高查詢效率
    的頭像 發(fā)表于 01-09 15:21 ?795次閱讀

    windows服務(wù)器備份mysql腳本

    osimport reimport datetimeimport subprocess## 需要備份數(shù)據(jù)庫(kù)的登錄信息mysql_host = { 'test': '10.10.3.207'}db_user
    的頭像 發(fā)表于 01-02 09:14 ?664次閱讀

    云服務(wù)器 Flexus X 實(shí)例 MySQL 應(yīng)用加速測(cè)試

    文章目錄 目錄 文章目錄 ? 購(gòu)買配置 ? 基本配置參考如下: ? 連接服務(wù)器 ? 查詢MySQL狀態(tài) ? 啟動(dòng)MySQL ? 添加配置 ? 添加密碼并修改權(quán)限 ? 性能測(cè)試 ? C#插入數(shù)據(jù)測(cè)試
    的頭像 發(fā)表于 12-24 12:19 ?786次閱讀
    云服務(wù)器 Flexus X 實(shí)例 <b class='flag-5'>MySQL</b> 應(yīng)用加速測(cè)試

    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—Mysql數(shù)據(jù)庫(kù)表記錄丟失的數(shù)據(jù)恢復(fù)流程

    Mysql數(shù)據(jù)庫(kù)故障: Mysql數(shù)據(jù)庫(kù)表記錄丟失。 Mysql數(shù)據(jù)庫(kù)故障表現(xiàn): 1、Mysql數(shù)據(jù)庫(kù)表中無(wú)任何數(shù)據(jù)或只有部分?jǐn)?shù)據(jù)。 2、客戶端無(wú)法查詢到完整的信息。
    的頭像 發(fā)表于 12-16 11:05 ?982次閱讀
    數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—<b class='flag-5'>Mysql</b>數(shù)據(jù)庫(kù)表記錄丟失的數(shù)據(jù)恢復(fù)流程