频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

优化SQL Server的内存占用之执行缓存

来源: 作者: 出处:巧巧读书 2007-10-09 进入讨论组
下一页 1 2 3 4 

  在论坛上常见有朋友抱怨,说SQL Server太吃内存了。这里笔者根据经验简单介绍一下内存相关的调优知识。首先说明一下SQL Server内存占用由哪几部分组成。SQL Server占用的内存主要由三部分组成:数据缓存(Data Buffer)、执行缓存(Procedure Cache)、以及SQL Server引擎程序。

SQL Server引擎程序所占用缓存一般相对变化不大,则我们进行内存调优的主要着眼点在数据缓存和执行缓存的控制上。本文主要介绍一下执行缓存的调优。数据缓存的调优将在另外的文章中介绍。

  对于减少执行缓存的占用,主要可以通过使用参数化查询减少内存占用。

1、使用参数化查询减少执行缓存占用

  我们通过如下例子来说明一下使用参数化查询对缓存占用的影响。为方便试验,我们使用了一台没有其它负载的SQL Server进行如下实验。

  下面的脚本循环执行一个简单的查询,共执行10000次。

  首先,我们清空一下SQL Server已经占用的缓存:

  dbcc freeproccache

  然后,执行脚本:

  DECLARE @t datetime
  SET @t = getdate()
  SET NOCOUNT ON
  DECLARE @i INT, @count INT, @sql nvarchar(4000)
  SET @i = 20000
  WHILE @i <= 30000
  BEGIN
  SET @sql = 'SELECT @count=count(*) FROM P_Order WHERE MobileNo = ' + cast( @i as varchar(10) )
  EXEC sp_executesql @sql ,N'@count INT OUTPUT', @count OUTPUT
  SET @i = @i + 1
  END
  PRINT DATEDIFF( second, @t, current_timestamp )

  输出:

  DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

保留地址 http://www.qqread.com/sqlserver/2007/10/d348863.html 更多文章 更多内容请看系统优化大全SQL Server 数据处理专题SQL Server 索引和查询专题专题,或进入讨论组讨论。
下一页 1 2 3 4 
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章