码迷,mamicode.com
首页 > 其他好文 > 详细

postgres limit 分页的坑

时间:2020-04-09 10:43:16      阅读:99      评论:0      收藏:0      [点我收藏+]

标签:mysq   结果   规划   off   环境   还需   rom   sel   from   

环境: postgres11

同一条sql
SELECT * from alarmtype limit 3 OFFSET 0 ;
如果返回的id是0,1,2的记录
如果修改id为1的其中一个字段,再用上面的sql查询,你会发现返回的id可能会是0,2,3,

竟然是无序的,想使用limit,offset分页,还需要先排序!

引用别的哥们的翻译
查询优化器在生成查询规划的时候会考虑LIMIT,因此如果你给 LIMIT和OFFSET不同的东西,那么你很可能收到不同的规划(产生不同的行顺序)。 因此,使用不同的LIMIT/OFFSET值选择不同的查询结果的子集将生成不一致的结果, 除非你用ORDER BY强制一个可预料的顺序。这可不是臭虫; 这是一个很自然的结果,因为 SQL 没有许诺把查询的结果按照任何特定的顺序发出,除非用了ORDER BY来约束顺序。

mysql看到了估计会笑了,没有许诺啊。。

postgres limit 分页的坑

标签:mysq   结果   规划   off   环境   还需   rom   sel   from   

原文地址:https://blog.51cto.com/bomby/2485900

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!