select xxx from xx where date_create > 'xx' and date_create < 'xx'; -- 总数据量约 100w
此时加入分页参数
select xxx from xx where date_create > 'xx' and date_create < 'xx' limit index,1000
现在发现,当 index 大于 30w 的时候,查询速度直线下降[小于 30w 的时候,只要 1 秒,大于 30 万,需要 40 多秒],似乎以 30 万为分界点?
explain 看了下,走上的索引都是 date_create
求教下,这是什么原因导致查询差距巨大呢?
是 mysql 认为 limit 的起点过大?不如全表扫描?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.