gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 08:37:06 29 4
gpt4 key购买 nike

如何使用 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;
}

关于c# - 将数组传递给 SQL Server 存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24636669/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com