设为首页 加入收藏

TOP

sqlserver缓存计划-清除只使用一次的缓存计划
2015-11-21 02:04:04 来源: 作者: 【 】 浏览:0
Tags:sqlserver 计划 清除 使用 一次
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


 
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇sql数据类型总结 下一篇数据库防火墙如何防范SQL注入行为

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: