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).
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