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

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日

悬赏问题

  • ¥50 comsol温度场仿真无法模拟微米级激光光斑
  • ¥15 上传图片时提交的存储类型
  • ¥15 Ubuntu开机显示器只显示kernel,是没操作系统(相关搜索:显卡驱动)
  • ¥15 VB.NET如何绘制倾斜的椭圆
  • ¥15 在rhel8中安装qemu-kvm时遇到“cannot initialize crypto:unable to initialize gcrypt“报错”
  • ¥15 arbotix没有/cmd_vel话题
  • ¥20 找能定制Python脚本的
  • ¥15 odoo17的分包重新供应路线如何设置?可从销售订单中实时直接触发采购订单或相关单据
  • ¥15 用C语言怎么判断字符串的输入是否符合设定?
  • ¥15 通信专业本科生论文选这两个哪个方向好研究呀