梦魇梦狸º 2023-04-28 16:25 采纳率: 71.4%
浏览 24

mysql排序,次要排序乱序问题

请教一个问题,mysql如果指定了排序,比如order by age, 如果age相同就会按照主键进行排序,但如果sort含有null值,并且主键是bigint类型,并且数值过大,就会出现乱序(每次结果都相同的乱序),我想知道这是为什么,什么原理?

img


[图片]

如图,title是根据排序前的顺序取值的

  • 写回答

5条回答 默认 最新

  • 寒意漫彻山川 2023-04-28 16:42
    关注

    这个可能是因为在进行排序时,MySQL会对null值进行特殊处理,将其视为小于任何非null值。当按照age进行排序时,在age相同的情况下,由于主键是bigint类型,如果存在null值,MySQL会将其放在未知位置,而大于(或小于)这个位置的主键可能会出现无规律乱序的情况。由于每次查询的结果集可能不同,因此导致看起来是乱序,但实际上是数据位置不固定的结果。
    COALESCE函数可以将null值替换为一个指定的值,这将确保在排序时不会出现未知位置的情况。

    评论

报告相同问题?

问题事件

  • 创建了问题 4月28日