Mysql中一千万条数据怎么快速查询
作者:java冢狐 发布时间:2024-01-15 06:57:05
标签:Mysql,千万数据,查询
目录
普通分页查询
如何优化
偏移量大
采用id限定方式
优化数据量大问题
普通分页查询
当我们在日常工作中遇到大数据查询的时候,第一反应就是使用分页查询。
mysql支持limit语句来选取指定的条数数据,而oracle可以使用rownum来选取
mysql分页查询语句如下:
SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset
第一个参数用来指定第一个返回记录行的偏移量
第二个参数指定返回记录行的最大数目
当相同的偏移量时,数据量越大,花费时间越长
当相同的数据量时,偏移量越大,花费时间越长
如何优化
经过上面的总结,我们可以很清晰的看到当偏移量大,数据量大的时候,查询的时间还是挺多的,所以我们就针对这两种来着手优化
偏移量大
采用子查询方式
我们可以先定位偏移位置的id,然后再查询数据
select * from test limit 1000000,10
select id from test limit 1000000,1
select * from test where id>=(select id from test limit 1000000,1)limit 10
?通过执行我们可以发现,第一条花费时间最大,第三条比第一条稍微好一点,而且子查询使用索引速度更快。
但是只是适用于id递增的情况
采用id限定方式
这种方法要求更高,id必须是连续递增,而且还得计算id的范围,然后使用between,sql如下:
select * from test where id between 1000000 and 1000100 limit 100;
select * from test where id>=1000000 limit 100
结果很快
这里limit是限制了条数,没有采用偏移量
优化数据量大问题
返回结果的数据量也会直接影响速度
减少不需要的列,查询效率会明显提升
来源:https://blog.csdn.net/issunmingzhi/article/details/108357871
0
投稿
猜你喜欢
- 如下所示:device = torch.device("cuda:0" if torch.cuda.is_availab
- 1、用apt-get安装mysql#更新一下apt 仓库sudo apt-get update#安装mysql-servicesudo ap
- 想想你在一家公司里做表格,现在有一个下面这样的excel表摆在你面前,这是一个员工每个月工资的表,现在假设,你要做的事情,是填充好后面几个月
- 将json转为结构体时,经常会遇到无法确定某个字段类型的情况。在Go中可以使用interface 任意类型来解决。// convert js
- 在正文前,先简短介绍自己。我任职于广州的某个网站服务公司的系统开发员,主要任务是以.Net编写各种web系统,例如CMS.EIP。大家都知道
- 新手,看到很多网页上有显示/隐藏的菜单,可以显示隐藏层的同时控制FLASH的播放与停止。找了好久都找不到这个功能。。。还望高人指点当点击时就
- 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!!回归正题,我们所要的说的axios的封装和api接口的统一管理,其实主
- 分为服务端和客户端,要求可以有多个客户端同时操作。客户端可以查看服务器文件库中有什么文件。客户端可以从文件库中下载文件到本地。客户端可以上传
- Pygame的Draw绘图Pygame 中提供了一个draw模块用来绘制一些简单的图形状,比如矩形、多边形、圆形、直线、弧线等。pygame
- 将转储设备加入到SQL Server备份数据库的地方。在SEM中转储设备是可见性的,并且在设备上的信息被存储在主要数据库的sysdevice
- 博主最近试在服务器上进行spark编程,因此,在开始编程作业之前,要先搭建一个便利的编程环境,这样才能做到舒心地开发。本文主要有以下内容:1
- 背景在小站点上,直接用git来部署php代码相当方便,你的远程站点以及本地版本库都有一个版本控制,追踪问题或者回滚是很轻松的事情。因为在小公
- MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQLAB公司,在2008年1月16号被Sun公司收购。MySQL被广泛地应用在I
- 数据表DROP TABLE IF EXISTS tb_score;CREATE TABLE tb_score( i
- 前言vue是现在很火的一个前端MVVM框架,它以数据驱动和组件化的思想构建,与angular和react并称前端三大框架。相比angular
- 在所有信息技术领域,网页设计、网站设计长期是个几乎搞不清楚的、弱势的、被边缘化的职能职位。但近些年发展中,不断有远见卓识的从业者认识到,“设
- 前言发现本站没有一个靠谱的tp6记录行为日志的教程,于是就整理了一下自己在项目中已经投入使用的行为日志中间件的详细配置步骤供大家参考提示:先
- 开发的时候我都是使用XDebug在本地调试,但是最近加入一些项目中去,环境太复杂了,要在本地搭建一个开发环境真的太麻烦了,那么我们怎么使用x
- 系列最后一篇来说说Python中的类与对象,Python这门语言是无处不对象,如果你曾浅要了解过Python,你应该听过Python是一种面
- 下面介绍在Linux上利用python获取本机ip的方法.经过网上调查, 发现大致有两种方法, 一种是调用shell脚本,另一种是利用pyt