「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > BULK INSERT がストアド プロシージャの変数ファイル パスを受け入れないのはなぜですか?

BULK INSERT がストアド プロシージャの変数ファイル パスを受け入れないのはなぜですか?

2024 年 12 月 22 日に公開
ブラウズ:674

Why Doesn't BULK INSERT Accept Variable File Paths in Stored Procedures?

ストアド プロシージャを使用した一括挿入: トラブルシューティング

ストアド プロシージャを使用してデータを一括挿入しようとしたときに、開発者が構文エラーを検出しました。目標は、動作する BULK INSERT クエリをプロシージャに複製することでした。この問題とその解決策の分析は次のとおりです。

この問題は、ストアド プロシージャ内の BULK INSERT コマンドにファイル名を変数として渡そうとすることで発生します。残念ながら、これは BULK INSERT ではサポートされていない操作です。

変数を使用して失敗した試行の例を次に示します:

DECLARE @filename VARCHAR(255)
SET @filename = 'e:\5-digit Commercial.csv'

BULK INSERT ZIPCodes
FROM @filename
WITH

代わりに、BULK INSERT コマンドはハードコーディングされたファイル パスを想定します。この制限を回避するには、固定ファイル名の文字列として BULK INSERT ステートメントを構築し、それを動的 SQL として実行することを検討してください。

DECLARE @filepath NVARCHAR(500)
SET @filepath = N'e:\5-digit Commercial.csv'

DECLARE @bulkinsert NVARCHAR(2000)

SET @bulkinsert =
       N'BULK INSERT ZIPCodes FROM '''  
       @filepath  
       N''' WITH (FIRSTROW = 2, FIELDTERMINATOR = '','', ROWTERMINATOR = ''\n'')'

EXEC sp_executesql @bulkinsert

動的 SQL を使用すると、構築されたステートメントを実行して、元のストアド プロシージャの実装で発生した構文エラーを解決できます。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3