sql >> Database >  >> RDS >> Sqlserver

DataTable doorgeven aan opgeslagen procedure als argument

U kunt de opgeslagen procedure wijzigen om een ​​tabel te accepteren gewaardeerde parameter als invoer. Eerst moet u echter een door de gebruiker gedefinieerde tabel TYPE maken die overeenkomt met de structuur van de C#-gegevenstabel:

CREATE TYPE dbo.PersonType AS TABLE
(
    Name NVARCHAR(50), -- match the length of SomeTable.Column1
    Age INT
);

Pas je SPROC aan:

CREATE PROCEDURE dbo.InsertPerson
    @Person dbo.PersonType READONLY
AS
BEGIN
  INSERT INTO SomeTable(Column1, Column2) 
     SELECT p.Name, p.Age
     FROM @Person p;
END

Als u in C# de datatable aan de PROC-parameter bindt, moet u de parameter specificeren als:

parameter.SqlDbType = SqlDbType.Structured;
parameter.TypeName = "dbo.PersonType";

Zie ook het voorbeeld hier Passing a Table-Valued Parameter voor een opgeslagen procedure



  1. mysql_num_rows() verwacht dat parameter 1 resource is, boolean gegeven in C:\wamp\www

  2. Een inleiding tot Hadoop en Big Data

  3. Hoe grotere gegevens in de Oracle-tabellen invoegen/bijwerken?

  4. Hoe het REAL-type naar NUMERIEK af te ronden?