SQL Server Performance Tuning

Stored Procedures and RECOMPILE Option: When and Why to Use It

Updated
2 min read
Written by
Mark Varnas

What is the RECOMPILE option?

The compilation is the process when a query execution plan of a stored procedure is optimized based on the current database object’s state. This query execution plan is often stored in the cache to be quickly accessed.

Recompilation is the same process as a compilation, just executed again.

Why should you care about it?

When you use the stored procedure WITH RECOMPILE option, it gets a new execution plan every time it runs.

That means SQL Server will execute the same action multiple times, which can lead to performance degradation due to high CPU usage.

How can you list all stored procedures with a RECOMPILE option?

You can use the following script to list them from all databases:

EXECUTE master.sys.sp_MSforeachdb

USE [?];

SELECT DISTINCT Database_Name = DB_Name()
	,SP_Name = SO.name
	,ISR.SPECIFIC_SCHEMA AS Schema_Name
FROM sys.sql_modules AS SM
LEFT OUTER JOIN master.sys.databases AS sDB ON SM.object_id = DB_id()
LEFT OUTER JOIN dbo.sysobjects AS SO ON SM.object_id = SO.id
	AND type = '' P ''
LEFT OUTER JOIN INFORMATION_SCHEMA.ROUTINES AS ISR ON ISR.Routine_Name = SO.name
	AND ISR.SPECIFIC_CATALOG = DB_Name()
WHERE SM.is_recompiled = 1
OPTION (RECOMPILE);

How to fix them?

  1. When the stored procedure does not run often, this can probably be ignored.
  2. If the stored procedure runs frequently and further investigation is needed, recompilation may not be the best solution.

More information

Article by
Mark Varnas
Founder | CEO | SQL Veteran
Hey, I'm Mark, one of the guys behind Red9. I make a living performance tuning SQL Servers and making them more stable.

Managed SQL Server services, consulting, and emergency support from expert DBAs to improve performance, predictability, and cost.

Get started with Red9 today.

Contact us

Discover More

SQL Server Health Check SQL Server Migrations & Upgrades SQL Server Performance Tuning SQL Server Security SQL Server Tips

Discover what clients are saying about Red9

Red9 has incredible expertise both in SQL migration and performance tuning.

The biggest benefit has been performance gains and tuning associated with migrating to AWS and a newer version of SQL Server with Always On clustering. Red9 was integral to this process. The deep knowledge of MSSQL and combined experience of Red9 have been a huge asset during a difficult migration. Red9 found inefficient indexes and performance bottlenecks that improved latency by over 400%.

Rich Staats 5 stars
Rich Staats
Cloud Engineer
MetalToad

Always willing to go an extra mile

Working with Red9 DBAs has been a pleasure. They are great team players and have an expert knowledge of SQL Server database administration. And are always willing to go the extra mile to get the project done.
5 stars
Evelyn A.
Sr. Database Administrator

Boosts server health and efficiency for enhanced customer satisfaction

Since adding Red9 to the reporting and DataWarehousing team, Red9 has done a good job coming up to speed on our environments and helping ensure we continue to meet our customer's needs. Red9 has taken ownership of our servers ensuring they remain healthy by monitoring and tuning inefficient queries.
5 stars
Andrew F.
Datawarehousing Manager
See more testimonials