テーブル値パラメーターを使用してこれを行う方法を次に示します。これらは SQL 2008 で導入されたため、このルートを選択する場合、そのバージョンはソリューションに適しています。このテスト シナリオでは、プライマリ テーブルと、プライマリを指す外部キーを持つ関連テーブルを作成しています。
まず、テーブルのデータ型を作成します。
CREATE TYPE primary_tbltype AS TABLE
(personkey int NOT NULL PRIMARY KEY,
firstname varchar(30),
lastname varchar(30))
CREATE TYPE related_tbltype AS TABLE
(fk_personkey int NOT NULL,
accountnum varchar(30),
accountbalance money)
ストアド プロシージャを作成します。
CREATE PROCEDURE MySproc
@PrimaryTable primary_tbltype READONLY,
@RelatedTable related_tbltype READONLY
AS
BEGIN
DECLARE @CurrentKey INT
DECLARE @FirstName VARCHAR(30)
DECLARE @LastName VARCHAR(30)
DECLARE @AccountTotal MONEY
DECLARE PersonCursor CURSOR LOCAL FAST_FORWARD FOR
SELECT personkey, firstname, lastname FROM @PrimaryTable
OPEN PersonCursor
FETCH NEXT FROM PersonCursor INTO @CurrentKey, @FirstName, @LastName
WHILE @@FETCH_STATUS= 0 BEGIN
SELECT @AccountTotal = SUM(accountbalance) FROM @RelatedTable
WHERE fk_personkey = @CurrentKey
PRINT @FirstName + ' ' + @LastName + ' - account total: ' + CONVERT(VARCHAR(30), @AccountTotal)
FETCH NEXT FROM PersonCursor INTO @CurrentKey, @FirstName, @LastName
END
END;
そして、これを試すためのテストデータを次に示します。
DECLARE @primaryTVP primary_tbltype
DECLARE @relatedTVP related_tbltype
INSERT INTO @primaryTVP values (1, 'John', 'Cleese')
INSERT INTO @primaryTVP values (2, 'Eric', 'Idle')
INSERT INTO @primaryTVP values (3, 'Graham', 'Chapman')
INSERT INTO @relatedTVP values (1, '29310918', 28934.33)
INSERT INTO @relatedTVP values (2, '123123', 3418.11)
INSERT INTO @relatedTVP values (2, '33333', 666.66)
INSERT INTO @relatedTVP values (3, '554433', 22.22)
INSERT INTO @relatedTVP values (3, '239482', 151515.15)
EXEC MySproc @primaryTVP, @relatedTVP;
TVP を使用する利点のいくつかはここで説明されており、セットベースの操作にも参加できます。