在sql中不指定Order by,排序是按照主鍵嗎?答案是不一定。舉個(gè)例子:
查詢AttendanceEmpRank表,主鍵是AttendanceEmployeeRankId,而且是聚集索引
執(zhí)行下面的語(yǔ)句,發(fā)現(xiàn)第一句不指定Order by的結(jié)果跟第二句不一樣。
再看看執(zhí)行計(jì)劃,我們可以知道,第一句用到的是Date索引,而第二句用的是主鍵索引.
再看看另一組sql和查詢結(jié)果:
執(zhí)行計(jì)劃中用到的索引也是不同的:
所以得出結(jié)論:在不指定Order by的情況下,sqlserver會(huì)根據(jù)執(zhí)行計(jì)劃實(shí)際查詢方式來(lái)得到數(shù)據(jù),而執(zhí)行計(jì)劃會(huì)根據(jù)sql中很多的因素(的查詢列,where條件,order by等)而使用不同的索引,最終出來(lái)的結(jié)果很可能是不同的。
新聞熱點(diǎn)
疑難解答
圖片精選