使用查询分析器调整SQL服务器脚本

查询分析|服务器|脚本

我喜欢把SQL服务器所捆绑的工具看作是倒金字塔型的,诊断和检查一般问题的工具在顶端,寻找和诊断问题具体区域的工具在底部。除了提供一种编写SQL脚本的便捷方式之外,在你需要解决特定SQL脚本里明确问题的时候,查询分析器(Query Analyzer)还是所需要使用的资源。如果你需要指出哪个查询正在保持着某个特定表格的锁定状态,你也会希望使用查询分析器。

查询分析器的关键诊断特性是它能够显示某个查询的执行计划。这个执行计划会向你提供各种类型的有用信息,例如在查询的执行期间如何以及何时使用或者不使用索引。它还会提供许多其他的细节,例如排序、平行(parallelism)、嵌套循环,以及SQL服务器在执行指定查询时必须做的其他事情。

计划的好处

有了查询分析器,你就可以查看预计计划而不需要运行查询本身,或者在查询执行之后查看真实的计划。很显然,真实的计划会更加准确,因为它是从物理上对数据库运行查询的。但是对于系统负载巨大和/或长期的查询,这种方法可能就不是最好的选择了。在典型情况下,当我认为某个特定的查询有问题的时候,或者如果我预计有一个查询会在应用程序里被足够频繁地调用以至于可能会导致性能问题的时候,我就会运行这个工具。

你可以通过把SQL表达式输入查询分析器再按[Ctrl]L来查看预计的执行计划。执行计划然后就会显示在结果(Results)面板的选项卡里。执行计划在刚开始的时候可能比较难读,因为它不像英语一样是从左往右读的,而是从右往左读的。

运行中的计划

这里有一个你可以跟着做的例子,从这个例子里你可以看到如何使用查询分析器来查看一个执行计划。考虑一下下面查询,它会从Northwind数据库里返回某个雇员所在的地点和相关地区:
 
SELECT
TerritoryDescription, RegionDescription
FROM
Employees e
JOIN EmployeeTerritories et ON e.employeeid = et.employeeid
JOIN Territories t ON et.territoryid = t.territoryid
JOIN Region r ON t.regionid = r.regionid
WHERE
e.employeeid = 1
ORDER BY
TerritoryDescription, RegionDescription
 
这个查询的结果显示:一号EmployeeId在东部(Eastern)有两个地区,如图A所示。

图A

查询结果
图B显示了SQL服务器从示例查询所生成的预计执行。这个图标中的每个节点都代表着SQL服务期执行示例查询所采取的步骤。要注意,每个节点包括一个预计的相对消耗,以及执行计划被显示的时候SQL服务器所使用的每个索引的名称。

图B

执行计划
你可以把鼠标放在执行计划的每个节点上以获取更多关于该步骤的信息,例如该节点所代表的操作类型、受影响的行数,以及和该步相关的消耗的分解。C显示的是图B里针对第一个节点的额外信息。这些弹出窗口里的信息能够提示你可以对查询做出哪些改进,如果能够改进的话。

图C

和索引调节向导一起使用

你可以将查询分析器和SQL服务器的索引调节向导(Server’s Index Tuning Wizard,ITW)一起使用。我通常使用SQL服务器的Profiler来收集要送入ITW的数据。但是有时候,我会使用查询分析器,如果我认为它代表着我正在进行测试时的某种活动类型的话。你可以从查询(Query)菜单来访问ITW;它能够对在活动编辑面板里的SQL脚本做出性能建议。

时间: 2025-01-27 12:37:40

使用查询分析器调整SQL服务器脚本的相关文章

使用查询分析器调整SQL服务器

我喜欢把SQL服务器所捆绑的工具看作是倒金字塔型的,诊断和检查一般问题的工具在顶端,寻找和诊断问题具体区域的工具在底部.除了提供一种编写SQL脚本的便捷方式之外,在你需要解决特定SQL脚本里明确问题的时候,查询分析器(Query Analyzer)还是所需要使用的资源.如果你需要指出哪个查询正在保持着某个特定表格的锁定状态,你也会希望使用查询分析器.查询分析器的关键诊断特性是它能够显示某个查询的执行计划.这个执行计划会向你提供各种类型的有用信息,例如在查询的执行期间如何以及何时使用或者不使用索引

通过查询分析器对比SQL语句执行效率

可以方便地对不同的SQL语句进行效率对比.首先打开查询分析器,将查询菜单中的"显示执行计划"."显示服务器跟踪"."显示客户统计"都选中. 在编辑窗口中输入要进行对比的SQL语句,比如不同方式的查询: SELECT *FROM CRM_FWDWHERE RQ BETWEEN '2006-06-01' AND '2006-06-02'SELECT *FROM CRM_FWDWHERE DATEDIFF(DAY, RQ, '2006-06-01')

如何通过查询分析器清除sql server数据库日志

1.查看数据库或是日志文件大小exec sp_helpfile [数据库] 不加数据库名称 则查询当前数据库大小与数据库日志大小 2.收缩数据库DBCC SHRINKFILE ([数据库],大小)

求救!带参数的存储过程,在sqldatasource的查询分析器中执行正常,但用querystring网页传递时不正常。

问题描述 参数是在地址栏传的,命令按钮内容如下:DimstrURLAsStringstrURL="<scriptlanguage='javascript'>window.open('Default2.aspx?Begin_Date="&TextBox3.Text&""&Mid(DropDownList5.Text,1,2)&":00:00&City_name="&DropDownList

SQL Server 查询分析器快捷键集合

下表列出 SQL Server 查询分析器提供的所有键盘快捷方式. 活动 快捷方式 书签:清除所有书签. CTRL-SHIFT-F2 书签:插入或删除书签(切换). CTRL+F2 书签:移动到下一个书签. F2 功能键 书签:移动到上一个书签. SHIFT+F2 取消查询. ALT+BREAK 连接:连接. CTRL+O 连接:断开连接. CTRL+F4 连接:断开连接并关闭子窗口. CTRL+F4 数据库对象信息. ALT+F1 编辑:清除活动的编辑器窗格. CTRL+SHIFT+DEL 编

查询分析器登陆非默认端口的远程Sql Server

server|查询分析 这几天在搞Web开发的时候,经常需要连接Sql Server ,但是Sql Server是internet上的服务器,服务商就给了一段SqlConnectionString,但是在连接串中发现Sql服务器并没有使用默认的1433端口,于是乎就想查询分析器应该登陆不了,结果验证了我的想法是对的.这样的话要想就只能在程序中写个简单的Sql执行程序,方法很笨不直观.操作作困难.容易发生异常.数据库维护困难..基于这么多的缺陷,决定放弃这种笨拙的方式,在网上用了很多关键字仍然找不

SQL Server企业管理器和查询分析器

如果主数据库发生故障,那么微软的SQL Server可能会怦然倒下.看看如何面对这种事件,了解如何用企业管理器和查询分析器修复主数据库. 作为一名微软SQL Server的管理员,您必须知道如何修复一个崩溃的主数据库.主数据库保存有您的登录信息,以及最重要的.指向您所有数据库的指针.如果没有主数据库,您就无法成功地启动SQL Server.在本文里,我将向您介绍在发生崩溃的情况下如何修复主数据库,并告诉您如何重建主数据库,如果有必要的话. 制定预案 制定一个应对崩溃和/或主数据库故障的预案十分重

SQL查询分析器清除被注入恶意病毒代码

在SQL查询分析器执行以下代码就可以了. 01.declare @t varchar(255),@c varchar(255) 02.declare table_cursor cursor for select a.name,b.name 03.from sysobjects a,syscolumns b ,systypes c 04.where a.id=b.id and a.xtype='u' and c.name 05.in ('char', 'nchar', 'nvarchar', 'v

在查询分析器中,通过SQLDMO来得到脚本

查询分析|脚本 --用以下脚本,可以得到任意对象的创建时的脚本,网上好像也流传有,但属于自己的东西用着还是感觉舒坦.--增加快捷键后,然后在查询分析器中按相应的快捷键就能显示对象的脚本.SET QUOTED_IDENTIFIER ON GOSET ANSI_NULLS ON GO     ALTER    procedure sp_script        @objectname varchar(50)asdeclare @databasename varchar(50) set @datab