Можете да промените съхранената процедура, за да приема таблица стойностен параметър като вход. Първо обаче ще трябва да създадете дефинирана от потребителя таблица TYPE, която съответства на структурата на C# DataTable:
CREATE TYPE dbo.PersonType AS TABLE
(
Name NVARCHAR(50), -- match the length of SomeTable.Column1
Age INT
);
Коригирайте своя 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
В C#, когато обвържете таблицата с данни към параметъра PROC, трябва да посочите параметъра като:
parameter.SqlDbType = SqlDbType.Structured;
parameter.TypeName = "dbo.PersonType";
Вижте също примера тук Предаване на таблица със стойност Параметър към съхранена процедура