码迷,mamicode.com
首页 > 数据库 > 详细

sqlserver缓存计划-清除只使用一次的缓存计划

时间:2015-03-12 15:04:48      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:sqlserver清除plan cach   sqlserver cache   

<pre name="code" class="sql">plan cache很大,将只使用一次的缓存计划清除,而不用清除整个cache.

declare @sid varbinary(64)
declare cur01 cursor for
select  plan_handle from 
(
SELECT  plan_handle  
FROM sys.dm_exec_cached_plans AS cp 
CROSS APPLY sys.dm_exec_sql_text(cp.plan_handle) st
WHERE cp.cacheobjtype = N'Compiled Plan'
AND cp.objtype IN (N'Adhoc', N'Prepared')
AND cp.usecounts =1 
and  text   like 'select%'
) c
open cur01
fetch next from cur01 into @sid
while @@fetch_status=0
begin
DBCC FREEPROCCACHE(@sid)
fetch next from cur01 into @sid
end
close cur01
deallocate cur01
go


sqlserver缓存计划-清除只使用一次的缓存计划

标签:sqlserver清除plan cach   sqlserver cache   

原文地址:http://blog.csdn.net/yangzhawen/article/details/44221653

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!