科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道SQL Server 2000优化SELECT语句方法(4)

SQL Server 2000优化SELECT语句方法(4)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文是SQL Server SQL语句优化系列文章的第一篇。该系列文章描述了在Micosoft’s SQLServer2000关系数据库管理系统中优化SELECT语句的基本技巧。

作者:InnovateDigital.com 来源:InnovateDigital.com 2007年8月30日

关键字: select 数据库 SQL Server SQL Server 各版本

  • 评论
  • 分享微博
  • 分享邮件

我们将展示几个SHOWPLAN_TEXT 输出的例子。为了避免冗余,我将不重复上面SET命令的展示.在这个部分里所提供的查询都将代替这个脚本中的标签并且都象上面展示的一样“包装”。

事实上SHOWPLAN有两个版本:SHOWPLAN_ALL和SHOWPLAN_TEXT。他们提供的信息基本上一样。然而,SHOWPLAN_ALL输出的结果是准备给图形查询工具的而不是给听众的。我们在这整篇文章中将用到SHOWPLAN_TEXT,可提供更可读的格式输出。下面的简单查询选择authors表的所有行。因为我们没有提供where子句所以它除了扫描整个表别无选择:select * form authors

在下面的表中SHOWPLAN_TEXT输出的结果没有格式化,我们不得不从SHOWPLAN_ALL的输出中整理出更多的可读信息:

SHOWPLAN_TEXT SHOWPLAN_ALL
StmtTextStmtText
---------------------------------  
|--Clustered Index Scan |--Clustered Index Scan
(OBJECT:([pubs].[dbo]. (OBJECT:([pubs].[dbo].

[authors].[UPKCL_auidind])) [authors].[UPKCL_auidind]))
StmtID  NodeID  Parent
---------  --------  -------
 2   2   1
 PhysicalOp LogicalOp 
 ------------  ----------------
NULL NULL

Clustered Index scan  Clustered Index scan

Argument
---------------------------------------------
 1
OBJECT:([pubs].[dbo]. ].[UPKCL_auidind])
DefindedValues
---------------------------------------
23

 _ <all columns in table>_
EstimatedRows   EstimateIO   EstimatedCPU
------------------  -------------  --------
 23   NULL  NULL

23 0.01878925 5.1899999E-5 
 AvgRowSizeotalSubtreeCost
 ------------------------------------
 NULL  3.7682299E-2

1113.7682299E-2 

 OutputList
 -----------------------------------------
 NULL
  _ <all columns in table>_

 Warnings  TypeParallel  EstimateExecutions
 --------  -------------------------
 NULL   SELECT   0NULL
 NULPLAN_ROW01.0

这里重要的不同是SHOWPLAN_ALL语句返回了很多有用的调优信息,但这些很难理解和应用。

SHOWPLAN 操作

SHOWPLAN操作,有时叫做“标签”(tag),其中一部分操作非常清晰地说明了SQL Server的做法,而其它一些操作将把人难住。这些操作分成物理操作和逻辑操作。物理操作描述被用来处理查询的物理算法,例如,执行一个索引查找。逻辑操作描述语句中使用的关系代数操作,如聚合运算等。SHOWPLAN的结果被细分非具体的步骤分成几步。每个查询的物理操作代表一个独立步骤。步骤通常会伴有一个逻辑操作,但不是所有的步骤都包括逻辑操作。此外,大部分的步骤都有一个操作(要么逻辑操作要么物理操作)和一个参数。参数是操作所影响的查询组件。关于所有执行计划步骤的讨论内容非常繁多。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章