我正在尝试导入正确引用的CSV文件,这意味着只有在包含逗号的情况下才会引用数据,例如:
41, Terminator, Black
42, "Monsters, Inc.", Blue
Run Code Online (Sandbox Code Playgroud)
我观察到第一行正确导入,但第二行错误以建议引用的逗号被视为字段分隔符.
我见过这样的建议
更改字段终止符
FIELDTERMINATOR = ' ""'
但是,我的CSV文件仅引用需要它的字段,因此我不相信该建议会起作用.
SQL Server的BULK IMPORT语句可以导入正确引用的CSV文件吗?怎么样?
我需要将一个大型CSV文件导入SQL服务器.我正在使用这个:
BULK
INSERT CSVTest
FROM 'c:\csvfile.txt'
WITH
(
FIELDTERMINATOR = ',',
ROWTERMINATOR = '\n'
)
GO
Run Code Online (Sandbox Code Playgroud)
问题是我的所有字段都被引号("")包围,所以一行实际上看起来像:
"1","","2","","sometimes with comma , inside", ""
Run Code Online (Sandbox Code Playgroud)
我可以以某种方式批量导入它们并告诉SQL使用引号作为字段分隔符吗?
编辑:使用'","'作为分隔符的问题,如在建议的示例中那样:大多数示例的作用是,它们是否导入数据,包括第一个"在第一列和最后一个"在最后,然后他们继续把它剥离出来.我的第一个(也是最后一个)列是datetime,不允许将"20080902"导入为datetime.
从我一直在阅读的内容来看,我认为FORMATFILE是可行的方式,但文档(包括MSDN)非常缺乏帮助.