使用 SELECT TOP 100 Percent 进行中间实现
在 SQL Server 2005 之前,可以采用一种称为“中间实现”的技术来强制 SQL Server通过在视图定义中包含 TOP 100 PERCENT 来遵守 ORDER BY 子句SELECT 语句。
但是,它的用途已超出动态 SQL 语句中的视图定义范围。在这种情况下,SELECT TOP 100 PERCENT 的主要目的是利用中间物化。此技术涉及通过将 ORDER BY 子句放置在 TOP 100 PERCENT 构造中来创建中间结果集。
此技术可能有用的一个示例是当您需要对嵌套查询的结果应用过滤器时。考虑以下查询:
SELECT foo FROM (SELECT foo FROM MyTable WHERE ISNUMERIC (foo) = 1) bar WHERE CAST(foo AS int) > 100
在此示例中,内部查询返回一个结果集,然后在外部查询中过滤该结果集。但是,内部查询中的 ORDER BY 子句可能不会被执行,从而导致不可预测的结果。
通过将 SELECT TOP 100 PERCENT 添加到内部查询,您可以强制中间实现:
SELECT foo FROM (SELECT TOP 100 PERCENT foo FROM MyTable WHERE ISNUMERIC (foo) = 1 ORDER BY foo) bar WHERE CAST(foo AS int) > 100
这种中间物化确保内部查询的结果集在外部查询中过滤之前进行排序,从而提供所需的结果
需要注意的是,只有在必要时才应谨慎使用此技术,因为服务器配置的更改(例如补丁级别、架构、索引、行计数)可能会破坏其功能。
以上是SELECT TOP 100 PERCENT 如何在 SQL Server 中启用中间实现?的详细内容。更多信息请关注PHP中文网其他相关文章!