mysql数据库的默认排序_各数据库无order by时的默认排序

2022-10-27 11:27:49

title: 各数据库无order by时的默认排序

date: 2018-08-03 18:48:07

tags: 数据库

MySQL:

对于 MyISAM 表 ,Select 默认排序是按照物理存储顺序显示的。

而InnoDB 表,会按主键的顺序排列。

Oracle:

oracle对无order by的语句返回的结果不进行排序,oracle此时的处理方式是按照数据的物理存储顺序来读取数据。因为rowid是每行数据的地址,所以有时候看起来会像是使用rowid排序的。但这个顺序是可能被打乱的,在表的数据被删除后,rowid会被新插入的数据占用。所以一个无order by查询结果看起来也可能是个杂乱无章的。oracle的数据库实现就一个原则,怎么快怎么效率高就怎么来。大多数情况下不需要排序还非得按主键排序这不是浪费资源么?这和oracle的表结构是有关系的,因为oracle的表结构默认是按堆存放的。按堆存放的意思就是,随便存,存的时候就是乱序的。如果你建表的时候就是建的按索引组织的表,那么它返回的时候就会默认排序了。

sqlserver:

在不指定Order by的情况下,sqlserver会根据执行计划实际查询方式来得到数据,而执行计划会根据sql中很多的因素(的查询列,where条件,order by等)而使用不同的索引,最终出来的结果很可能是不同的。

DB2:

DB2的尚不清晰,排序好像与sort heap相关。

  • 作者:滤石水
  • 原文链接:https://blog.csdn.net/weixin_30855927/article/details/113302332
    更新时间:2022-10-27 11:27:49