sqlserver快取計劃-清除只使用一次的快取計劃
阿新 • • 發佈:2019-02-05
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