性能测试培训:sql server性能测试分析局部变量的性能影响

poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标。在poptest的loadrunner的培训中,为了提高学员性能优化的经验,加入了很多服务器方面的优化知识,为性能调优的能力打下基础。今天sqlserver的性能测试方面的知识。(大家对课程感兴趣,请加qq:564202718)

性能测试的分析都有一定的方法和思路,这次我们来看看sqlserver方面的性能的知识。

数据库开发者在存储过程和脚本中使用局部变量,但是,局部变量会影响查询的性能。我们创建一个表并插入一些测试数据:

USE AdventureWorks

GO

CREATE TABLE TempTable

      (tempID UNIQUEIDENTIFIER,tempMonth INT, tempDateTime DATETIME )

GO

INSERTINTOTempTable (tempID, tempMonth, tempDateTime)

SELECT NEWID(),(CAST(100000*RAND() AS INT) % 12) + 1 ,GETDATE()

GO 100000 -- (EXECUTE THIS BATCH 100000 TIME)

-- Create an index to support our query

CREATE NONCLUSTERED INDEX [IX_tempDateTime] ON [dbo].[TempTable]

([tempDateTime] ASC)

INCLUDE ( [tempID]) WITH ( ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ONON [PRIMARY]

GO

然后我们做一个简单的查询:

SET STATISTICS IO ON

GO

SELECT FROM TempTable

WHERE tempDateTime > ‘2015-10-10 03:18:01.640‘

Table ‘TempTable‘. Scan count 1, logical reads 80, physical reads 0, read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob read-ahead reads 0.

检查这个执行计划以及索引检索的属性,你会发现预估行数是实际行数的两倍,但并不会太影响执行计划,因为优化器选择了最合适的查询方法:

查询优化器根据基本统计直方图来预估数据行数,即:EQ_ROWS + AVG_RANGE_ROWS (77 + 88.64286) DBCC SHOW_STATISTICS (‘dbo.TempTable‘, IX_tempDateTime)

现在我们修改 SELECT 语句以使用局部变量,你会发现查询优化器使用了一个不同的查询计划,这是一个更耗时的计划,为什么?

DECLARE @RequiredDate DATETIME

SET @RequiredDate = ‘2015-10-10 03:18:01.640‘

SELECT FROM TempTable

WHERE tempDateTime  > @RequiredDate

Table ‘TempTable‘. Scan count 1, logical reads 481, physical reads 0, read-ahead reads 0, lob logical reads 0, lob physical reads 0, lob read-ahead reads 0.

预估值和实际值差别更大,相当于查询优化器无法选择最适合的查询计划,因为错误的预估值。因为查询优化在执行时并不清楚局部变量值,导致无法使用统计直方图。

不等式运算符的情况

在我们的查询中使用的不等式运算符,因此查询优化器使用了一个简单的 30% 的算式来预估。

Estimated Rows =(Total Rows * 30)/100 = (100000*30)/100 = 30000

等式运算符的情况

DECLARE @RequiredDate DATETIME

SET @RequiredDate = ‘2012-07-10 03:18:01.640‘

SELECT FROM TempTable

WHERE tempDateTime  = @RequiredDate

如果在局部变量中使用等式运算符,那么查询优化器又会选择不同的公式,即 精确度 * 表记录总数. 执行下面查询可获取精确的值

DBCC SHOW_STATISTICS(‘dbo.TempTable‘, IX_tempDateTime)

All Density = 0.0007358352 Total Number of Rows in Table = 100000

Estimated Rows = Density * Total Number =  0.0007358352 *  100000 = 73.5835

时间: 2024-08-24 11:13:33

性能测试培训:sql server性能测试分析局部变量的性能影响的相关文章

公司内部培训SQL Server传统索引结构PPT分享

公司内部培训SQL Server传统索引结构PPT分享 下载地址 http://files.cnblogs.com/files/lyhabc/SQLServer%E4%BC%A0%E7%BB%9F%E7%B4%A2%E5%BC%95%E7%BB%93%E6%9E%84.ppt PPT有不对的地方,多多拍砖o(∩_∩)o

SQL Server调优基础系列 - 性能调优介绍

前言 关于SQL Server调优系列是一个庞大的内容体系,非一言两语能够分析清楚,本篇先就在SQL 调优中所最常用的查询计划进行解析,力图做好基础的掌握,夯实基本功!而后再谈谈整体的语句调优. 通过本篇了解如何阅读和理解查询计划.并且列举一系列最常用的查询执行运算符. 技术准备 基于SQL Server2008R2版本,利用微软的一个更简洁的案例库(Northwind)进行解析. 一.区别不同的运算符 在所有T-SQL语句在执行的时候,都会将语句分解为一些基本的结构单元,这些结构单元统称为:运

SQL Server管理员必备技能之性能优化

SQL Server作为企业必不可少的服务之一,所以对于管理员的日常运维是一个极大的挑战,管理员对于服务保证是非常重要的,所以作为管理员首先就是对数据及服务的备份,然后熟悉的掌握灾难恢复,这只是前提,后续我们需要对服务进行优化,今天说说SQL Server的日常优化,我们企业每年微软都会对环境内的SQL Server进行健康检查,在此总结了一些日常需要注意的问题,分享给有需要的朋友. 1.首先是备份.备份的方式有很多,可根据自己的爱好进行选择操作.具体备份哪些呢? SQL Server 维护一组

SQL Server 订单分析

select distinct PurchasedByContactID as PurchasedByContactID into #SP from BASKET.. BaseOrderTracker(nolock ) where OrderDate> '2014-2-1' and OrderDate< '2014-3-1' and OrderTypeID =15 and OESourceID= 2 and StageID= 10400 select distinct PurchasedByC

sql server 索引分析相关sql

select object_id('dbo.FT_CFP_TRADE_SUBACCOUNT') select * from sys.partitions where [object_id]=1467256382 select * from sys.allocation_units where container_id=72057594139049984 select * from sys.system_internals_allocation_units where container_id=7

SQL Server 统计信息对查询的影响

优化器根据开消确定选择哪个执行计划,开消又与行数统计信息有关,默认情况下统计信息是在优化的过程中自动生成的. 一旦列被标记为需要统计信息,查询优化器就会查找该列以有的统计信息,如果以有一个统计信息,下一步就会对它进行,检查 以确定它足够新.如果过期就重建统计信息.(由此可见统计信息是基于列的). -----------------------------------------------------------------------------------------------------

sql server 中 bigint 和 datetime 性能比较

-- 创建表 create table Test_tbl ( ID varchar(40) primary key nonclustered, IntCol int, DateCol datetime ) --================================================================================== -- [100w数据测试] --==============================================

SQL Server 性能优化实战系列(二)

SQL Server datetime数据类型设计.优化误区 一.场景 在SQL Server 2005中,有一个表TestDatetime,其中Dates这个字段的数据类型是datetime,如果你看到表的记录如下图所示,你最先想到的是什么呢? (图1:数据列表) 你看到这些数据,是不是觉得这样的设计既浪费了存储空间,又使得这个列的索引增大,查询起来更慢,你也想使用一些其它的数据类型来代替这个datetime吧? 其实大家都是这么想的,这个方向是100%正确的,但是在写这篇文章以前,我进入了两

最有效地优化 Microsoft SQL Server 的性能

为了最有效地优化 Microsoft SQL Server 的性能,您必须明确当情况不断变化时,性能将在哪些方面得到最大程度的改进,并集中分析这些方面.否则,在这些问题上您可能花费大量的时间和精力,而性能却得不到明显的改善. 以下大部分信息并不解决由多用户并发使用而引起的性能问题."Maximizing Database Consistency and Concurrency"(数据库一致性和并发性的最大化)一文以及其他知识库文章将对这个复杂的主题做单独的讨论,前者可从 SQL Ser