首页 > 代码库 > MYSQL limit 和 order by 的数据不可靠的bug
MYSQL limit 和 order by 的数据不可靠的bug
今天遇到一种情况,记下来:
select * from tablewhere a=xxx and b=xxxorder by c limit 8,2;
select * from tablewhere a=xxx and b=xxxorder by c limit 10,2
按理来说这两个语句是应该返回完全不同的结果
可是在我的程序里返回的有一行是相同的
比如第一句结果是:
张三
李四
第二句结果是:
王五
李四
这是完全不能接受的,也不应该出现的
究其原因是因为order by 不可靠,然后 对于张三李四王五这三行来说, 他们 被 order by 的字段 也就是 c 字段又都是一样的 就会出现这种情况
把语句改成:
select * from tablewhere a=xxx and b=xxxorder by c , id desclimit 8,2
即可
MYSQL limit 和 order by 的数据不可靠的bug
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。