Du kan ændre den lagrede procedure for at acceptere en tabel værdisat parameter som input. Først skal du dog oprette en brugerdefineret tabel TYPE, som matcher strukturen i C# DataTable:
CREATE TYPE dbo.PersonType AS TABLE
(
Name NVARCHAR(50), -- match the length of SomeTable.Column1
Age INT
);
Juster din SPROC:
CREATE PROCEDURE dbo.InsertPerson
@Person dbo.PersonType READONLY
AS
BEGIN
INSERT INTO SomeTable(Column1, Column2)
SELECT p.Name, p.Age
FROM @Person p;
END
I C#, når du binder datatabellen til PROC-parameteren, skal du angive parameteren som:
parameter.SqlDbType = SqlDbType.Structured;
parameter.TypeName = "dbo.PersonType";
Se også eksemplet her Bestå en tabel-vurderet Parameter til en lagret procedure