V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
jojojo
V2EX  ›  MySQL

mysql in 什么情况下会全表扫描?

  •  
  •   jojojo · 2019-09-26 16:14:42 +08:00 · 6648 次点击
    这是一个创建于 1886 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我有一个表 a,里面有 6 条数据,id 是主键,当我用

    id in (1,2,3)
    

    这时候查看 explain 发现 type 是 range,key 是 primary。当我用

    id in (1,2,3,4)
    

    这时候 type 是 all

    想问一下,为什么会发生这样的情况

    6 条回复    2019-09-29 09:43:05 +08:00
    linjiayu
        1
    linjiayu  
       2019-09-26 16:20:59 +08:00
    数据量超过百分之几,应该是 33%,不过看样子不是
    arrow8899
        2
    arrow8899  
       2019-09-26 17:20:48 +08:00
    你要把整个 sql 发出来,计算查询成本涉及到很多因素;
    你可以用 `EXPLAIN FORMAT=JSON 你的 sql 语句` 查看更详细的信息,主要关注 cost 字段
    InternetExplorer
        3
    InternetExplorer  
       2019-09-26 17:24:08 +08:00
    数据很少的时候 mysql 会自己选择扫表还是用索引
    Dogergo
        4
    Dogergo  
       2019-09-26 17:57:04 +08:00
    mysql 觉得全表扫描的代价更低。
    optional
        5
    optional  
       2019-09-26 18:06:32 +08:00
    虽然没看过源码,但是可以猜测下,mysql 会判断如果走索引会扫描几个 page,
    如果 page < n 就会走索引
    Aresxue
        6
    Aresxue  
       2019-09-29 09:43:05 +08:00
    eq_range_index_dive_limit
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   927 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 22:40 · PVG 06:40 · LAX 14:40 · JFK 17:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.