好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 關于MySQL索引的深入解析

關于MySQL索引的深入解析

熱門標簽:400電話申請信用卡 銷售語音電話機器人 安徽ai電話電銷機器人有效果嗎 萊西市地圖標注 常州網絡外呼系統開發 外呼系統電銷受騙 巫師三血與酒地圖標注 走過哪個省地圖標注 在哪里申請400電話

前言

我們知道,索引的選擇是優化器階段的工作,但是優化器并不是萬能的,它有可能選錯所要使用的索引。一般優化器選擇索引考慮的因素有:掃描行數,是否排序,是否使用臨時表。

使用explain分析sql

explain是很好的自測命令,勤于使用explain有助于我們寫出更合理的sql語句以及建立更合理的索引:

mysql> explain select * from t where (a between 1 and 1000) and (b between 50000 and 100000) order by b limit 1;
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra               |
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
| 1 | SIMPLE   | t   | NULL    | range | a,b      | b  | 5    | NULL | 50223 |   1.00 | Using index condition; Using where |
+----+-------------+-------+------------+-------+---------------+------+---------+------+-------+----------+------------------------------------+
1 row in set, 1 warning (0.01 sec)

其中:

table字段:表示關于哪張表;
type字段:system,const,eq_reg,ref,range,index,all。一般來說要達到range級別以上;

system、const:可以將查詢的變量轉為常量,如id=1;id為主鍵或唯一鍵;
eq_ref:訪問索引,返回某單一行的數據,通常在連接時出現,查詢使用的索引為主鍵或唯一鍵;
ref:訪問索引,返回某個值得數據(可能是多行),通常使用=時發生;
range:使用索引返回一個范圍內的行信息,如使用>,,between
index:以索引的順序進行全表掃描,雖然有索引不用排序,但是要全表掃描;
all:全表掃描

key字段:實際使用的索引;

key_len字段:使用的索引長度(在不損失精度的情況下,長度越短越好);

ref字段:顯示索引的哪一列被使用了;

rows字段:MySQL認為檢索需要的數據行數;

Extra字段:查詢的額外信息,主要有以下幾種:

using index:使用了索引
using where:使用了where條件
using tmporary:用到臨時表去處理當前查詢
using filesort:用到額外的排序,如order字段無索引
range checked for eache record(index map:N):無索引可用
using index for group-by:表名可以在索引中找到分組所需的所有數據,不需要查詢實際的表

一般遇到Using temporary和Using filesort就要想辦法優化一下了,因為用不到索引。

MySQL怎么計算需要檢索的行數

實際中,MySQL所統計的掃描行數并不是精確值,有時候甚至會相差很遠,而掃描行數則是基于索引的基數來計算的。

在MySQL中,通過采樣統計的方式去獲取索引基數:系統默認選取 N 個數據頁,統計數據頁上不同值得平均值,然后乘以索引的頁面數得到基數,而且MySQL會在變更的數據行數超過 1/M 時來觸發重做索引統計的操作。

在MySQL中,有2種存儲索引統計的方式,可以通過設置innodb_stats_persistent參數來選擇:

設置為 on 的時候,表示統計信息會持久化存儲。這時,默認的 N 是 20,M 是 10。

設置為 off 的時候,表示統計信息只存儲在內存中。這時,默認的 N 是 8,M 是 16。

一般來說,基數統計出來的數據和真實的行數沒有很大差距,但是涉及到刪除數據新增數據比較頻繁的數據表,可能會出現數據表有10萬條數據但是基數統計卻有20萬的情況,這就可能是MVCC在作怪了,因為MySQL的InnoDB的事務支持,需要維持多個數據版本,就有可能某些事務還沒結束,還在使用刪除了很久的數據導致已刪除的數據空間無法釋放,而新增的數據又開辟了新的空間,那么這時候就導致基數統計中數據頁數量可能出現失誤,出現較大誤差。

一個很好的修正方式就是執行analyze table 表名,該命令用來重新統計索引信息。

索引選錯了我們到底怎么辦

當我們正確的建立必須的索引后,大部分情況下,優化器其實并不會選擇錯索引,當我們遇到索引選錯的情況下,該怎么去處理呢?

1、使用force index強制使用某個索引。

2、轉換思路,優化一下sql語句可能就會使用到該使用的索引。

3、新建更合適的索引或刪除掉誤用到的不合理的索引。(有些時候,可能真的是這個索引是多余的,還不是最優的,優化器又剛好使用到了它)。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • mysql 添加索引 mysql 如何創建索引
  • MySQL索引類型總結和使用技巧以及注意事項
  • MySQL查看、創建和刪除索引的方法
  • MySQL 創建索引(Create Index)的方法和語法結構及例子
  • MySQL 主鍵與索引的聯系與區別分析
  • Mysql索引會失效的幾種情況分析
  • 基于mysql全文索引的深入理解
  • 解決MySQL中IN子查詢會導致無法使用索引問題
  • Mysql中的Btree與Hash索引比較
  • MYSQL中常用的強制性操作(例如強制索引)

標簽:果洛 鞍山 黃石 陽江 河北 赤峰 來賓 煙臺

巨人網絡通訊聲明:本文標題《關于MySQL索引的深入解析》,本文關鍵詞  關于,MySQL,索引,的,深入,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于MySQL索引的深入解析》相關的同類信息!
  • 本頁收集關于關于MySQL索引的深入解析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 一级做a爰片久久毛片无码免费| 国内久久久久久久久久| 把腿扒开让我添个痛快动态图 | 美女被到爽视频免费下载| 美女脱一光二净18以上视频| 4个混血大学生精油按摩| 国产理伦片一级A片我的课| 成年女人视频网站免费m| 午夜dj在线观看视频免费| 国产成人aaa在线视频免费观看| 91丨国产丨白浆秘?洗澡吊死| 91女人18毛片水多国产| 久久久伊人一本精品久久综合精品| 菠萝菠萝菠萝蜜菠萝菠萝5亚瑟 | 福利在线国产| 亚洲欧美日韩中文字幕| 粗长+灌满h双龙h男男室友猛| 猛男大g又粗又长| 韩国一级理黄论片| 国产香蕉精品视频| 午夜dj在线观看视频在线观看| 夜夜躁狠狠躁日日躁视频蜜臀AV| 动漫被吸乳羞羞漫画| 香港三级黄色| 日本午夜大片a在线观看| 1769国产资源免费入口| 摸花核| 欧美一级片在线播放| 继攵女h娇喘抽搐喷潮h| 伊大人香蕉久久网| 插到花心了| 口述我与子的性经过| 国产美女裸体无遮挡免费视频| 调教不知火舞| 他吃着我胸摸着我下面| 2019天天操夜夜操| 日韩毛片免费观看| 把亲妺妺强h在线播放| 无码做爰欢H肉网站在线看| 动漫女被黄漫免费视频| 看成年女人免费午夜视频|