百万数据下mysql条件查询及分页查询的注意事项


当前第2页 返回上一页

1

2

3

4

select * from news

where cate = 1 and id > (select id from news2 where cate = 1 order by id desc limit 500000,1 )

order by id desc

limit 0,10

注意条件 id > 后面使用了news2 这张表!

运行时间 1.23秒,我们可以看到运行时间缩减了近20倍!!数据在10万左右是查询时间可以保持在0.5秒左右,是一个逐步接近我们能够容忍的值!

但是1秒对于服务器来说依然是一个不能接受的值!!还有什么可以优化的办法吗??我们尝试了一个伟大的变化:

将 news2 的存储引擎改变为innodb,执行结果是惊人的!

1

2

3

4

select * from news

where cate = 1 and id > (select id from news2 where cate = 1 order by id desc limit 500000,1 )

order by id desc

limit 0,10

只需要 0.2秒,非常棒的速度。为什么会有怎么大的差别呢?请观看下一篇 mysql存储引擎详解。

以上就是百万数据下mysql条件查询及分页查询的注意事项的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

mysql存储不了中文字符串怎么办

mysql和sql是干什么的?

mysql数据库基础篇sql窗口函数示例解析教程

mysql数据库锁按粒度可以分为什么

mysql产生随机数并连接字符串如何实现

如何理解数据库事务隔离级别及脏读、不可重复读、幻读

终于理解 mysql 索引要用 b+tree ,而且还这么快

mysql执行计划的深入分析

mysql常用引擎总结分享

php+mysql分布式事务与解决方案深入理解

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...