作成前にストアド プロシージャが存在することを確認する
データベース管理では、クライアント データベースにストアド プロシージャを作成するのが一般的なタスクです。ただし、T-SQL 構文の制限のため、作成前にそれらが存在しないことを確認するのは困難な場合があります。
コード アプローチ
この質問は、作成前に既存のストアド プロシージャを確認する必要性を強調しています。作成ステートメントを実行します。回避策として、作成前に既存のものを削除するという人もいますが、これは推奨されません。
より洗練された解決策は、IF NOT EXISTS 構文を使用することです。
IF NOT EXISTS (SELECT * FROM sys.objects WHERE type = 'P' AND name = 'MyProc') EXEC('CREATE PROCEDURE [dbo].[MyProc] AS BEGIN SET NOCOUNT ON; END') GO ALTER PROCEDURE [dbo].[MyProc] AS ...
このスクリプトストアド プロシージャ MyProc がデータベースにすでに存在するかどうかを確認します。そうでない場合は、プレースホルダー ステートメントを使用して作成します。存在する場合は、作成をスキップして ALTER PROCEDURE ステートメントに進み、既存のプロシージャを更新します。
利点
このアプローチ:
その他の考慮事項
以上が最初にストアド プロシージャを削除せずにストアド プロシージャが存在することを確認するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。