千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > mysql 不加条件查询速度挺快,加上过滤条件就特别慢是为什么?

mysql 不加条件查询速度挺快,加上过滤条件就特别慢是为什么?

来源:千锋教育
发布人:xqq
时间: 2023-10-13 15:18:26 1697181506

一、mysql 不加条件查询速度挺快,加上过滤条件就特别慢是为什么

不加条件查询,如果是自增主键的话,会顺序读盘,顺序读取磁盘数据的话,速度可以很快;添加过滤条件后,如果过滤条件不走索引,数据可能会随机读取,所以性能没有顺序读取速度快。

举个例子:

有一个放了很多五颜六色珠子的箱子,你从中拿10个珠子只需要抓一把数一下就可以了,但是如果让你拿10个红色的珠子呢?当然就慢了。

而如果按照颜色拿珠子是经常要做的事情,那么,怎么样才能提高效率,加快速度呢?把箱子里分成一格一格,每个格子摆一个颜色的珠子,这样不就快了吗?当然,在往箱子里放珠子的时候需要按照颜色摆放。这一格一格对应到数据库就是索引。

再扩展一下,如果你是卖小商品的,你有很多种商品,但你的箱子数量是有限的,如果每样商品放一个箱子,那么箱子数量不够,如果无规律摆放,有空档就塞进去,那么找起来就麻烦了,那么怎么去做呢?估算每样商品的数量,然后一号箱子放a,b,c三样物品,二号箱子放d,e两件物品,等等,这样再查找物品时,就不需要每个箱子每个箱子的查找。那么,箱子对应到数据库其实就是表空间。

延伸阅读:

二、声明式与命令式

命令式(Imperative)和声明式(Declarative)是很早就有的概念,比如 SQL、HTML、CSS 是典型的声明式语言,而我们使用的绝大部分编程语言都是命令式的。

命令式编程就像它的名字一样,它由开发者我们一步一步的告述计算机,执行一系列的操作,然后得到想要的结果,起主要作用的是开发者,计算机只是帮助开发者执行计算而已。

而声明式编程却与此相反,它不是告述计算机做什么做,而是直接告述计算它想要的结果,至于怎么做,由预先写好的程序依据一定的算法由计算机自动推算出来。

声明式与命令式的主要区别在于,声明式描述的是结果,它不关心过程。比如 SQL,我们告述数据库的是,我们要查询某张表满足某某条件的数据,但我们并不会告述数据库怎么去查,怎么查数据是数据库系统自己关心的事情。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT