![97f306dcf67c6ee76569de6c54f97cdb.png](https://i-blog.csdnimg.cn/blog_migrate/885a5a152e42a207a111e3bd54181f4e.jpeg)
mysql 语句中如果没有使用 order by 来排序,通常会用 主键正序排列,但是有的时候不是这样,来看一个实例。
实例
群友问:请教一个问题,mysql 默认排序问题,当sql 语句 的排序没有指定 主键(id)的时候是按着什么规则排序的呢?
![b460deffa95517509188f9579fa76436.png](https://i-blog.csdnimg.cn/blog_migrate/05229039706c989a912b0ee7cc58646d.jpeg)
这个 sql 语句 当 hit_count = 0 和 uptime = 0 时 的数据和 跟 limit_count 变化
![42747b9bb0575266accaae4aff83b1be.png](https://i-blog.csdnimg.cn/blog_migrate/f852f29ed1cdafd4f9adccea81f5a734.jpeg)
根据 id 来看,当 uptime 为0时,的确是混乱了,order by是不是应该相当于没有效果。
讨论
来自网友的回答:
![bdf427c9c0549a4b5da5c0861b271da1.png](https://i-blog.csdnimg.cn/blog_migrate/2f2324a65f0060533e43c4e0d811b85c.jpeg)
大概意思就是数据储存的表 不是有序的,而是一个集合,在没有使用 order by 来排序的时候,不能默认就是 根据主键排序。
查阅
然后从 stackoverflow 上查了一下,找到了这样的回答:
There is no default sort order. Even if the table has a clustered index, you are not guaranteed to get the results in that order. You must use an order by clause if you want a specific order.
大概意思:没有默认的排序顺序。即使表具有聚集索引,也不能保证按该顺序获得结果。如果需要特定的顺序,则必须使用ORDER BY子句。
![18c116590e2b09e60cbbf24bf2049b99.png](https://i-blog.csdnimg.cn/blog_migrate/971ff54d3af1f32b9df50aba9ec57b4a.jpeg)
结论
到这大家应该明白了,mysql 的没有默认排序,如果需要排序一定要加上 order by 来排序,大家有没有遇到过这样的问题,欢迎一起来讨论,如果有不对的地方,请指正,感谢。