请教一个问题,mysql如果指定了排序,比如order by age, 如果age相同就会按照主键进行排序,但如果sort含有null值,并且主键是bigint类型,并且数值过大,就会出现乱序(每次结果都相同的乱序),我想知道这是为什么,什么原理?
如图,title是根据排序前的顺序取值的
这个可能是因为在进行排序时,MySQL会对null值进行特殊处理,将其视为小于任何非null值。当按照age进行排序时,在age相同的情况下,由于主键是bigint类型,如果存在null值,MySQL会将其放在未知位置,而大于(或小于)这个位置的主键可能会出现无规律乱序的情况。由于每次查询的结果集可能不同,因此导致看起来是乱序,但实际上是数据位置不固定的结果。
COALESCE函数可以将null值替换为一个指定的值,这将确保在排序时不会出现未知位置的情况。
你只指定了按sort排序,null是会比数值类型小的,这没有问题
至于次要排序,你又没指定,默认就按id排序了,这不是已经完美的按id排序了吗
sql语句中,order by sort,就是按sort字段排序,null肯定排在前面,这个是没有问题的。当sort字段同为null值的那些记录,由于没有指定别的排序字段,就会按默认的排序规则(例如:主键。)来排序。 这个很好理解。
是把为null的判定为最小的了,然后排序的。
具体原理可以看下面这篇文章:
https://blog.csdn.net/weixin_35702787/article/details/113224866