Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Wie füge ich eine Datentabelle in eine SQL Server-Datenbanktabelle ein?

Erstellen Sie einen User-Defined TableType in Ihrer Datenbank:

CREATE TYPE [dbo].[MyTableType] AS TABLE(
    [Id] int NOT NULL,
    [Name] [nvarchar](128) NULL
)

und definieren Sie einen Parameter in Ihrer Stored Procedure :

CREATE PROCEDURE [dbo].[InsertTable]
    @myTableType MyTableType readonly
AS
BEGIN
    insert into [dbo].Records select * from @myTableType 
END

und senden Sie Ihre DataTable direkt zum SQL-Server:

using (var command = new SqlCommand("InsertTable") {CommandType = CommandType.StoredProcedure})
{
    var dt = new DataTable(); //create your own data table
    command.Parameters.Add(new SqlParameter("@myTableType", dt));
    SqlHelper.Exec(command);
}

Um die Werte innerhalb der gespeicherten Prozedur zu bearbeiten, können Sie eine lokale Variable mit demselben Typ deklarieren und eine Eingabetabelle darin einfügen:

DECLARE @modifiableTableType MyTableType 
INSERT INTO @modifiableTableType SELECT * FROM @myTableType

Dann können Sie @modifiableTableType bearbeiten :

UPDATE @modifiableTableType SET [Name] = 'new value'