插入.csv文件到SQL Server与BULK INSERT和重新排序列(Insert .csv

2019-09-29 06:47发布

我做一个ASP.NET应用程序,我想将数据插入到CSV文件中的我的SQL Server。 我用这个SQL命令这样做是:

BULK
INSERT Shops
FROM 'C:\..\file.csv'
WITH
(
   FIELDTERMINATOR = ';',
   ROWTERMINATOR = '\n'
);

它漂亮的作品,但我有一个ID列AUTO INCREMENT选项。 我想插入的列重新排序到SQL Server增量automatiquely ID列。

我如何能做到这一点与BULK方法?

(当然,我不希望manualy编辑.csv文件:P)

Answer 1:

就像我在我的评论说:你不能,批量插入正好在泵的数据,你不能以任何方式转换数据。 你可以做的是批量插入到临时表(S)和使用INSERT语句做你需要做的事情。

你可以像下面这样做:

-- Create staging table
SELECT   TOP 0 *
INTO     Shops_temp
FROM     Shops;


-- Bulk insert into staging
BULK INSERT Shops_temp
FROM 'C:\..\file.csv'
WITH
(
   FIELDTERMINATOR = ';',
   ROWTERMINATOR = '\n'
);


-- Insert into actual table, use SELECT for transformation, column order etc.
INSERT INTO Shops(name, etc..)
SELECT name
,      etc..
FROM   Shops_temp;


-- Cleanup
DROP TABLE Shops_temp;


文章来源: Insert .csv file into SQL Server with BULK INSERT and reorder columns