„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie gieße ich Variablen für Masseneinsätze in T-SQL richtig?

Wie gieße ich Variablen für Masseneinsätze in T-SQL richtig?

Gepostet am 2025-03-25
Durchsuche:421

How to Correctly Cast Variables for Bulk Inserts in T-SQL?

Variablen für Bulk In t-SQL

In T-SQL fügen Sie die Bulk-Einfügeanweisung zu, dass Daten aus einer externen Datei in eine Tabelle importiert werden können. Wenn jedoch eine Zeichenfolgenvariable als Datenquelle verwendet wird, kann ein Fehler auftreten.

Problem:

Der folgende T-SQL-Code schlägt mit einem Fehler (Teil einer gespeicherten Prozedur) fehl. Set @csvFile = n't: \ x.csv '; Bulk Insert [DBO]. [TstagingTable] - von n't: \ x.csv '- Diese Zeile funktioniert Von @csvFile - diese Zeile schlägt fehl MIT ( Fieldeterminator = ',', Roweterminator = '\ n',, Firstrow = 2 )

DECLARE @CSVfile nvarchar(255);
SET @CSVfile = N'T:\x.csv';
BULK INSERT [dbo].[TStagingTable]
-- FROM N'T:\x.csv' -- This line works
FROM @CSVfile -- This line fails
WITH
(
FIELDTERMINATOR = ',',
ROWTERMINATOR = '\n',
FIRSTROW = 2
)

falsche Syntax in der Nähe des Schlüsselworts 'mit'.

Incorrect syntax near the keyword 'with'.
Grund:

in der Bulk -Insert -Anweisung erfordert eine literale String als Eingabedatei. Wenn eine Variable verwendet wird, muss sie an einen wörtlichen String gegossen werden.

Lösung:

, um die Variable @csvFile zu einem buchstäblichen String zu gießen, verwenden Sie die folgende dynamische T-SQL-Syntax:

@q nvarchar (Max). Setzen Sie @q = 'Bulk Insert [tstagingTable] Von 'char (39) @csvfile char (39)' ' MIT ( Fieldeterminator = '', '', Roweterminator = '' \ n '', Firstrow = 1 ) ' exec (@q)

declare @q nvarchar(MAX);
set @q=
    'BULK INSERT [TStagingTable]
    FROM ' char(39) @CSVfile char(39) '
    WITH
    (
    FIELDTERMINATOR = '','',
    ROWTERMINATOR = ''\n'',
    FIRSTROW = 1  
    )'
exec(@q)
.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3