Sử dụng SQL động để đưa biến tên tệp vào một chuỗi bằng câu lệnh chèn số lượng lớn và sử dụng sp_executesql
để thực hiện nó. Bạn có thể muốn thêm một số kiểm tra lỗi để kiểm tra xem đường dẫn có hợp lệ không, v.v.
CREATE PROCEDURE [importFile] (@filePath VARCHAR(MAX))
AS
BEGIN
CREATE TABLE #Temp
(
row1 int,
row2 varchar(5),
row3 bit
)
DECLARE @SQL NVARCHAR(MAX) = ''
SET @SQL = N'
BULK INSERT #Temp
FROM ''' + @filePath + '''
WITH (
FIELDTERMINATOR = '','',
ROWTERMINATOR = ''\n''
)'
-- ...
EXEC sp_executesql @SQL
END
-- to run it:
EXEC importFile 'd:\test.csv'