"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > BULK INSERT가 저장 프로시저의 변수 파일 경로를 허용하지 않는 이유는 무엇입니까?

BULK INSERT가 저장 프로시저의 변수 파일 경로를 허용하지 않는 이유는 무엇입니까?

2024년 12월 22일에 게시됨
검색:652

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