目标:理解oracle,mysql,sqlserve 三个数据库中的排序效率问题!
Oralce:
oracle对无order by的语句返回的结果不进行排序,oracle此时的处理方式是按照数据的物理存储顺序来读取数据。因为rowid是每行数据的地址,所以有时候看起来会像是使用rowid排序的。但这个顺序是可能被打乱的,在表的数据被删除后,rowid会被新插入的数据占用。所以一个无order by查询结果看起来也可能是个杂乱无章的。
oracle的数据库实现就一个原则,怎么快怎么效率高就怎么来。大多数情况下不需要排序还非得按主键排序这不是浪费资源么?这和oracle的表结构是有关系的,因为oracle的表结构默认是按堆存放的。按堆存放的意思就是,随便存,存的时候就是乱序的。如果你建表的时候就是建的按索引组织的表,那么它返回的时候就会默认排序了。
任何时候要排序就要加上order by
参考博客:https://blog.csdn.net/indieinside/article/details/45912911
Mysql:
Mysql 有默认排序的 如果要增加查询效率可以 在后面加上 ORDER BY NULL
sqlserver:
在不指定Order by的情况下,sqlserver会根据执行计划实际查询方式来得到数据 ,默认不排序