Передача массива в хранимую процедуру SQL Server
Как передать переменную массива в хранимую процедуру SQL Server с помощью С# и вставить значения массива в целую строку?
Спасибо заранее.
Таблица SQL Server:
ID | Product | Description
-------------------------------
8A3H | Soda | 600ml bottle
массив С#:
string[] info = new string[] {"7J9P", "Soda", "2000ml bottle"};
Хранимая процедура SQL Server:
ALTER PROC INSERT
(@INFO_ARRAY ARRAY)
AS
BEGIN
INSERT INTO Products VALUES (@INFO_ARRAY)
END
Ответы
Ответ 1
В SQL Server 2008 и более поздних версиях
Создайте тип SQL Server следующим образом:
CREATE TYPE dbo.ProductArray
AS TABLE
(
ID INT,
Product NVARCHAR(50),
Description NVARCHAR(255)
);
Измените свою процедуру в SQL Server:
ALTER PROC INSERT_SP
@INFO_ARRAY AS dbo.ProductArray READONLY
AS
BEGIN
INSERT INTO Products SELECT * FROM @INFO_ARRAY
END
Затем вам нужно создать объект DataTable
со значениями для передачи в С#:
DataTable dt = new DataTable();
//Add Columns
dt.Columns.Add("ID");
dt.Columns.Add("Product");
dt.Columns.Add("Description");
//Add rows
dt.Rows.Add("7J9P", "Soda", "2000ml bottle");
using (conn)
{
SqlCommand cmd = new SqlCommand("dbo.INSERT_SP", conn);
cmd.CommandType = CommandType.StoredProcedure;
SqlParameter dtparam = cmd.Parameters.AddWithValue("@INFO_ARRAY", dt);
dtparam.SqlDbType = SqlDbType.Structured;
}
Ответ 2
вот простой пример:
Я просматривал все примеры и ответы о том, как передать любой массив на сервер sql, пока не нашел этот linK, ниже как я применил его к моему проекту:
- Следующий код собирает массив в качестве параметра и вставляет значения этого
--array в другую таблицу
Create Procedure Proc1
@INFO_ARRAY ARRAY nvarchar(max) //this is the array your going to pass from C# code
AS
declare @xml xml
set @xml = N'<root><r>' + replace(@INFO_ARRAY,',','</r><r>') + '</r></root>'
Insert into Products
select
t.value('.','varchar(max)')
from @xml.nodes('//root/r') as a(t)
END
Надеюсь, вам понравится