eNet Technology Institute, All Rights Reserved
データベース システムの開発過程では、多くのストアド プロシージャを作成する必要があることがよくあります。形式を統一して開発プロセスを簡素化するために、ストアド プロシージャを自動的に生成するいくつかのストアド プロシージャを作成しました。以下にそれらについて簡単に紹介します。そのうちの 1 つは挿入プロセスの生成に使用され、もう 1 つは更新プロセスの生成に使用されます。
Sp_GenInsert
このプロセスの実行後、指定されたテーブルに対して完全な挿入プロセスが生成されます。元のテーブルに ID 列がある場合は、生成されたプロセス内の SET IDNTITY_INSERT ON ステートメントを手動で削除する必要があります。
構文は次のとおりです
sp_GenInsert < テーブル名 >, < ストアド プロシージャ名 >
northwind データベースを例に挙げます
sp_GenInsert 'Employees', 'INS_Employees'
最後に、Insert ストアド プロシージャが生成されます。それを利用することでさらに発展することができます。
Sp_GenUpdate
テーブルの更新ストアド プロシージャを生成します。構文は次のとおりです:
sp_GenUpdate < テーブル名 >,< ストアド プロシージャ名 >
northwind データベースを例に挙げます
sp_GenUpdate 'Employees','EmployeeID','UPD_Employees'
以下のストアド プロシージャを実行すると、以下が生成されます:
Create Procedure UPD_Employees
@EmployeeID int
@LastName nvarchar(40) 、
@FirstName nvarchar(20) 、
@Title nvarchar(60) 、
@TitleofCourtesy nvarchar(50) 、
@BirthDate datetime 、
@HireDate datetime 、
@Address nvarchar(120) 、
@City nvarchar(30) 、
@Region nvarchar(30) 、
@PostalCode nvarchar(20) 、
@country nvarchar(30) 、
@HomePhone nvarchar (48) 、
@Extension nvarchar(8) 、
@Phote image 、
@Notes ntext 、
@ReportsTo int 、
@PhotoPath nvarchar(510)
AS
UPDATE 従業員
SET
LastName = @ LastName、
FirstName = @FirstName、
Title = @Title、
TitleofCourtesy = @TitleofCourtesy、
BirthDate = @BirthDate、
HireDate = @HireDate、
Address = @Address、
City = @City、
Regin = @Regin、
PostalCode = @PostCode、
Country = @ Country、
HomePhone = @HomePhone、
Extension = @Extension、
Photo = @Photo
Notes = @Notes、
ReportsTo = @ReportsTo、
PhotoPath = @PhotoPath
WHERE EmployeeID = @EmployeeID
上記を使用 2 つのストアド プロシージャにより、多くの時間を節約できました。特に、テーブル構造を変更した後に各ストアド プロシージャを再構築するプロセスで発生します。これら 2 つのプロシージャを書き換えて、他のストアド プロシージャを自動的に生成できます。