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

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日

悬赏问题

  • ¥15 Java与Hbase相关问题
  • ¥20 bash代码推送不上去 git fetch origin master #失败了
  • ¥15 LOL外服加入了反作弊系统,现在游戏录像rofl文件离线都无法打开
  • ¥15 在centos7安装conda
  • ¥15 c#调用yolo3 dll文件获取的数据对不上
  • ¥20 WPF 如何实现多语言,label 和cs(live Charts)中是否都能翻译
  • ¥15 STM32F103上电短路问题
  • ¥15 打开软件提示错误:failed to get wglChoosePixelFormatARB
  • ¥15 (标签-python|关键词-char)
  • ¥15 python+selenium,在新增时弹出了一个输入框