MSSQL 的Top 和 MAX 效率测试

简介: 环境: MSSQL 2008, 都在没有使用缓存的情况下面执行 表中有8W 条记录 分类1有134条记录 分别测试了3个语句 -- A select 字段1 from 表1 WHERE Ftype='分类1' ORDER BY 字段1 -- B select ...

环境:

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。

目录
相关文章
|
SQL 移动开发 关系型数据库
PostgreSQL 与 MSSQL(SQL Server) 之间 数据相互迁移、导入、导出测试
标签 PostgreSQL , ms sql , SQL Server 背景 测试表结构 create table test (id int, info text); 从 PostgreSQL 导入 MSSQL MS SQL bcp与BULK INSERT都不支持stdin,所以我这里使用落地到文件的方法,从PostgreSQL导入MS SQL。
4962 0
|
9天前
|
测试技术 C语言
网站压力测试工具Siege图文详解
网站压力测试工具Siege图文详解
18 0
|
1月前
|
JavaScript jenkins 测试技术
这10款性能测试工具,收藏起来,测试人的工具箱!
这10款性能测试工具,收藏起来,测试人的工具箱!
|
1月前
|
人工智能 监控 测试技术
利用AI辅助工具提升软件测试效率
【2月更文挑战第17天】 随着科技的不断发展,人工智能(AI)在各个领域的应用越来越广泛。在软件测试领域,AI技术也发挥着重要作用。本文将探讨如何利用AI辅助工具提升软件测试效率,包括自动化测试、智能缺陷识别和预测等方面。通过引入AI技术,软件测试过程将变得更加高效、准确和可靠。
155 1
|
1月前
|
Web App开发 前端开发 测试技术
探索自动化测试工具:Selenium的威力与应用
探索自动化测试工具:Selenium的威力与应用
探索自动化测试工具:Selenium的威力与应用
|
28天前
|
测试技术
现代软件测试中的自动化工具与挑战
传统软件测试面临着越来越复杂的系统架构和不断增长的测试需求,自动化测试工具应运而生。本文将探讨现代软件测试中自动化工具的应用和挑战,深入分析其优势与局限性,为软件测试领域的发展提供思路和启示。
|
24天前
|
jenkins 测试技术 持续交付
现代软件测试中的自动化工具与挑战
随着软件开发领域的不断发展,自动化测试工具在测试过程中扮演着越来越重要的角色。本文将探讨现代软件测试中自动化工具的应用及面临的挑战,旨在帮助开发人员和测试人员更好地理解和应对自动化测试中的问题。
|
9天前
|
测试技术 Linux Apache
网站压力测试工具webbench图文详解
网站压力测试工具webbench图文详解
8 0