MSSQL|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 ASCselect @var01
速度和A写法一样
【MSSQL|MSSQL 的Top 和 MAX 效率测试】刚刚继续测试了一下
改成Top 100, Top 200速度很快
改成Top 1, Top 10速度都很慢,搞不懂MS。
转载于:https://www.cnblogs.com/DKSoft/p/3415345.html
推荐阅读
- 热闹中的孤独
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 一个人的旅行,三亚
- 布丽吉特,人生绝对的赢家
- parallels|parallels desktop 解决网络初始化失败问题
- 慢慢的美丽
- 尽力
- 一个小故事,我的思考。
- 家乡的那条小河