请教一个问题,mysql如果指定了排序,比如order by age, 如果age相同就会按照主键进行排序,但如果sort含有null值,并且主键是bigint类型,并且数值过大,就会出现乱序(每次结果都相同的乱序),我想知道这是为什么,什么原理?
[图片]
如图,title是根据排序前的顺序取值的
请教一个问题,mysql如果指定了排序,比如order by age, 如果age相同就会按照主键进行排序,但如果sort含有null值,并且主键是bigint类型,并且数值过大,就会出现乱序(每次结果都相同的乱序),我想知道这是为什么,什么原理?
如图,title是根据排序前的顺序取值的
这个可能是因为在进行排序时,MySQL会对null值进行特殊处理,将其视为小于任何非null值。当按照age进行排序时,在age相同的情况下,由于主键是bigint类型,如果存在null值,MySQL会将其放在未知位置,而大于(或小于)这个位置的主键可能会出现无规律乱序的情况。由于每次查询的结果集可能不同,因此导致看起来是乱序,但实际上是数据位置不固定的结果。
COALESCE函数可以将null值替换为一个指定的值,这将确保在排序时不会出现未知位置的情况。