U kunt de opgeslagen procedure wijzigen om een tabel te accepteren gewaardeerde parameter als invoer. Eerst moet u echter een door de gebruiker gedefinieerde tabel TYPE maken die overeenkomt met de structuur van de C#-gegevenstabel:
CREATE TYPE dbo.PersonType AS TABLE
(
Name NVARCHAR(50), -- match the length of SomeTable.Column1
Age INT
);
Pas je SPROC aan:
CREATE PROCEDURE dbo.InsertPerson
@Person dbo.PersonType READONLY
AS
BEGIN
INSERT INTO SomeTable(Column1, Column2)
SELECT p.Name, p.Age
FROM @Person p;
END
Als u in C# de datatable aan de PROC-parameter bindt, moet u de parameter specificeren als:
parameter.SqlDbType = SqlDbType.Structured;
parameter.TypeName = "dbo.PersonType";
Zie ook het voorbeeld hier Passing a Table-Valued Parameter voor een opgeslagen procedure