SQL Server TOP 一旦找到足够的行就会停止处理吗?

2024-01-27

当您使用 SQL Server 时TOP查询中的子句,一旦 SQL Server 引擎有足够的行来满足条件,它是否会停止搜索行TOP X需要退货吗?

考虑以下查询(假设 some_text_field 是唯一的并且未设置全文索引):

SELECT
    pk_id
FROM
    some_table
WHERE
    some_text_field = 'some_value';

and

SELECT TOP 1
    pk_id
FROM
    some_table
WHERE
    some_text_field = 'some_value';

第一个查询需要搜索整个表并返回找到的所有结果。不过,按照我们设置的方式,该查询实际上会返回一个值。所以,会使用TOP 1阻止 SQL Server 在找到匹配项后扫描表的其余部分?


是的,一旦找到足够的行,查询就会停止,并且不会查询表的其余部分。

但请注意,您可能希望有一个数据库可用于查询的索引。在这种情况下,获得第一场比赛和获得所有一场比赛之间实际上没有任何性能差异。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

SQL Server TOP 一旦找到足够的行就会停止处理吗? 的相关文章