ORDER BY排序后,用LIMIT取前几条,发现返回的结果集的顺序与预期的不一样。
例如:limit 0,10 与 limit 0,6 的结果不一致。
如果你把order BY 和 limit N 混合使用,mysql会在找排序结果中的第一个 “第N条记录” 时就停止,而不会排序整个结果集。如果排序是通过索引完成的,那么这个操作就会非常快。如果必须要通过数据文件排序,所有符合查询条件的记录都将被选中,并且所有的数据都将被排序,直到第一个 “第N条记录” 被找到。在第一条的数据都被找到之后,mysql不会继续把结果中剩余的数据进行排序。
这种实现行为的表现之一就是order by查询 在配合 limit 使用和不配合limit使用的情况下的返回值,排序情况是不同的
解决方案是 可以在order by子句中包含附加列,以使顺序具有确定性。