sp_recompile (Transact-SQL)
適用対象:SQL Server (サポートされているすべてのバージョン) Azure SQL Database
ストアド プロシージャ、トリガー、およびユーザー定義関数が次回実行時に再コンパイルされるようにします。 これは、プロシージャキャッシュから既存のプランを削除し、次にプロシージャまたはトリガーが実行された時点で新しいプランを作成する必要がある場合に行います。 イベント コレクションSQL Server Profilerイベント SP:CacheInsert は、イベント SP:Recompile ではなくログに記録されます。
構文
sp_recompile [ @objname = ] 'object'
引数
[ @objname= ] '@objname='
現在のデータベースにあるストアド プロシージャ、トリガー、テーブル、ビュー、またはユーザー定義関数の修飾名または非修飾名を指定します。 オブジェクト は nvarchar(776) で、既定値はありません。 object が ストアド プロシージャ、トリガー、またはユーザー定義関数の名前である場合、次回の実行時にストアド プロシージャ、トリガー、または関数が再コンパイルされます。 オブジェクトがテーブルまたはビューの名前である場合、テーブルまたはビューを参照するストアド プロシージャ、トリガー、またはユーザー定義関数はすべて、次回の実行時に再コンパイルされます。
リターン コードの値
0 (成功) または 0 以外の数値 (失敗)
注釈
sp_recompile は、現在のデータベース内でのみオブジェクトを検索します。
ストアド プロシージャ、トリガー、およびユーザー定義関数が使用するクエリは、コンパイル時にだけ最適化されます。 データベースにインデックスを追加したり、変更を加えたりすると、統計が変化するため、コンパイルされたストアド プロシージャ、トリガー、およびユーザー定義関数の効率が低下する場合があります。 そのテーブルに作用するストアド プロシージャやトリガーを再コンパイルすることにより、クエリを再び最適化できます。
Note
SQL Server、トリガー、およびユーザー定義関数を自動的に再コンパイルする場合は、これを行うのが便利です。
アクセス許可
指定したオブジェクトに対する ALTER 権限が必要です。
例
次の例では、Customer
テーブルを対象とするストアド プロシージャ、トリガー、およびユーザー定義関数が次回実行時に再コンパイルされます。
USE AdventureWorks2012;
GO
EXEC sp_recompile N'Sales.Customer';
GO
参照
CREATE PROCEDURE (Transact-SQL)
CREATE TRIGGER (Transact-SQL)
システム ストアド プロシージャ (Transact-SQL)