有个小需求,在表里根据页码和页数查询,并排序,很简单,3秒就写出的sql

1
select * from newslist order by id desc limit ${(currPage - 1) * pageSize},${pageSize} ;

前几页测试没什么问题,很快
0.2s,在接收范围之内,然后试了一下最后一页
???

1
select * from newslist order by id desc limit 538070,10;

直到chrome的http请求超时了,都没有返回,跑到navicat里面一跑,90多秒
查阅相关资料,会全表扫描,但是丢弃前538069页的内容

1
SELECT * FROM (select id from newslist limit ${(currPage - 1) * pageSize},${pageSize}) as a,newslist as n WHERE a.id = n.id

看似没有问题了,先根据唯一索引查询id,再根据id查询,但是又出问题
子查询查询的内容不是竟不是从1开始的

1
2
select id,title from newslist limit ${(currPage - 1) * pageSize},${pageSize}
select * from newslist limit ${(currPage - 1) * pageSize},${pageSize}

查询所有内容,查询主键id,和另外一个列的时候,排序结果又正常了
可能是当时建表的时候,id没有直接主键,插了几条数据再设置主键
网上有言论是存储时间不同,导致存在硬盘上的地址不连续云云。。。
聚集索引云云的

相关文章
评论
分享
  • 花式log

    各种控制台输出常见的控制台打印123456console.log() // 打印日志console.debug() // 打印调试console.error() // 打印错误console.info() // 打印信息...

    花式log
  • 微任务宏任务

    微任务队列宏任务队列 javascript是单线程,多线程都是模拟出来的, script、setTimeOut、setInterval是宏任务 Promise,process.nextTick是微任务 setTimeOut是n毫...

    微任务宏任务
  • functionalTemplate

    在使用iview表格的时候,定制组件,需要用到renderHeader API,看了一下如何传入render函数,结果惊为天人 12345678910111213141516export default { name:...

    functionalTemplate
  • 罗盘时钟

    罗盘时钟不刷抖音但是最近也听说了有很火的罗盘时钟,废话不多说直接上代码 123456789101112131415161718192021222324252627282930313233343536373839404142434445...

    罗盘时钟
  • 如何判定我点了margin?

    这个世界上唯有两样东西能让我们的心灵感到深深的震撼:一是我们头顶上灿烂的星云,二是我们心中崇高的道德法则。 one - 康德 前言页面的绑定事件都是绑定在DOM元素上的,诸如此类 123document.getElementById(...

    如何判定我点了margin?
  • 自动微信读书

    前言最近在学习ReactNative,真机调试的时候安装的ADB调试工具,突发奇想,既然PC可以操控手机,是不是可以做一些懒得做的事情 流程 通过USB链接真机调试 执行wifi调试 123adb tcpip 5555adb co...

    自动微信读书
  • docker-Dockerfile篇

    什么是DockerfileDockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明,相当于快速构建时候的脚本文件 获取images 首先明确需要获取的image版本,以目前LTS的nodejs版...

    docker-Dockerfile篇
  • Docker-安装篇

    what is DockerDocker 是一个开源的应用容器引擎换句话说就是运行的系统里的虚拟机,可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。优点是容...

    Docker-安装篇
  • 初探electron

    什么是 electron使用html、css、javascipt、nodejs来编写跨平台的客户端程序,可以使windows、linux、macos 优点一次代码编写,多端打包 起步

    初探electron
  • 粘贴图片上传功能

    粘贴图片并上传最近在写博客的时候,纯MarkDown语法写,但是发现图片是个需求,需要经常截图并且写到MarkDown里面之前的做法是用QQ截图,然后另存为到本地桌面,然后再上传,返回URI地址,贴到博客编辑器里面最近发现有些页面支持...

    粘贴图片上传功能