web-dev-qa-db-ja.com

配列を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
11
user3658439

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

次に、C#で渡す値を持つ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;
}
20
kerbasaurus

簡単な例を次に示します。

私はこれを見つけるまで、SQLサーバーに配列を渡す方法のすべての例と回答を検索してきました linK 、以下はプロジェクトにどのように適用したかです。

-次のコードは、配列をパラメーターとして取得し、その値を別のテーブルに挿入します。

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 

楽しんでください

2
Adam