将数组传递给SQL Server存储过程

如何使用C#将数组变量传递给SQL Server存储过程并将数组值插入整行?

提前致谢。

SQL Server表:

ID | Product | Description ------------------------------- 8A3H | Soda | 600ml bottle 

C#数组:

 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 

在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对象,其值包含在C#中传递:

 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; } 

这是一个更简单的例子:

我一直在搜索如何将任何数组传递给sql server的所有示例和答案,直到我找到这个linK ,下面是我如何将它应用到我的项目:

– 以下代码将获取一个Array作为参数,并将–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'' + replace(@INFO_ARRAY,',','') + '' Insert into Products select t.value('.','varchar(max)') from @xml.nodes('//root/r') as a(t) END 

希望你喜欢它