저장 프로시저를 사용하여 데이터 대량 삽입
대량 삽입 작업을 성공적으로 수행하는 쿼리를 생성했습니다. 그러나 이제 재사용성을 향상시키기 위해 이 쿼리를 저장 프로시저 내에 캡슐화하려고 합니다. 불행하게도 이 작업을 시도하는 동안 구문 오류가 발생했습니다.
문제의 핵심은 BULK INSERT 명령이 파일 이름을 변수로 허용할 수 없다는 것입니다. 코드가 구문적으로는 정확해 보이지만 다음 코드 조각은 실패합니다.
DECLARE @filename VARCHAR(255) SET @filename = 'e:-digit Commercial.csv' BULK INSERT ZIPCodes FROM @filename WITH
따라서 파일 이름을 BULK INSERT 문에 변수로 전달할 수 없습니다. 대신 BULK INSERT 문을 문자열로 동적으로 작성하고 동적 SQL을 사용하여 실행할 수 있습니다. 예는 다음과 같습니다.
DECLARE @filepath nvarchar(500) SET @filepath = N'e:-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
이 코드는 @filepath 변수에 파일 경로를 할당합니다. 그런 다음 BULK INSERT 문을 문자열로 구성하고 이를 @bulkinsert 변수에 저장합니다. 마지막으로 동적 SQL 프로시저 sp_executesql을 사용하여 생성된 문을 실행합니다. 이 접근 방식을 사용하면 파일 경로를 매개 변수화하고 저장 프로시저 내에서 BULK INSERT 문을 효과적으로 실행할 수 있습니다.
위 내용은 SQL 저장 프로시저에서 BULK INSERT와 함께 변수를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!