sql >> Databáze >  >> RDS >> Sqlserver

Předávání pole do uložené procedury serveru SQL

V SQL Server 2008 a novějších

Vytvořte typ v SQL Server takto:

CREATE TYPE dbo.ProductArray 
AS TABLE
(
  ID INT,
  Product NVARCHAR(50),
  Description NVARCHAR(255)
);

Změňte svůj postup v SQL Server:

ALTER PROC INSERT_SP
@INFO_ARRAY AS dbo.ProductArray READONLY
AS
BEGIN
    INSERT INTO Products SELECT * FROM @INFO_ARRAY
END

Poté budete muset vytvořit DataTable objekt s hodnotami k předání v 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;
}


  1. Jak vytvořit uživatele/databázi ve skriptu pro Docker Postgres

  2. Jak vložit aktualizovatelný záznam se sloupcem JSON v PostgreSQL pomocí JOOQ?

  3. Vytvoření pokročilejšího modelu se stavy uživatele, vlákna a příspěvku

  4. Úvod do kolekcí PL/SQL v databázi Oracle