MSSQL 的Top 和 MAX 效率测试

环境:

MSSQL 2008, 都在没有使用缓存的情况下面执行

表中有8W 条记录

分类1有134条记录

分别测试了3个语句

-- A
select 
  字段1
from 表1 
WHERE Ftype='分类1'
ORDER BY 字段1
-- B
select 
  Top 1 字段1
from 表1 
WHERE Ftype='分类1'
Order by 字段1 desc


-- C
select 
  MAX(字段1)
from 表1 
WHERE Ftype='分类1'

A 语句 很快几乎0秒

B 语句 需要近 8秒

C 语句和 B一样 需要8 秒

看来TOP和MAX的效率是及其的低啊

后来求最大值换了一个写法

declare @var01
select 
  @var01 = 字段1
from 表1 
WHERE Ftype='分类1'
ORDER BY 字段1 ASC

select @var01

速度和A写法一样

刚刚继续测试了一下

改成Top 100, Top 200速度很快

改成Top 1, Top 10速度都很慢,搞不懂MS。

原文地址:https://www.cnblogs.com/DKSoft/p/3415345.html