BCP到CSV文件,数据中带逗号

时间:2014-01-13 17:49:09

标签: sql sql-server bcp

我有一个调用存储过程的BCP进程。通常,我一直在执行此存储过程并将数据复制到Excel工作表,我将所有列指定为文本并将其另存为CSV。

我需要自动完成这项工作,并且一直在使用BCP命令,但到目前为止还存在问题。我的数据中有逗号,它将数据向左移动。这是我可以用格式文件或类似的东西克服的吗?

我宁愿不在proc本身的输出中引用它们。

1 个答案:

答案 0 :(得分:7)

BCP命令具有-t开关,用于指定字段终止符。在你的情况下,它是逗号或CHR(44)。

http://technet.microsoft.com/en-us/library/ms162802.aspx

要防止MS Excel在打开文件时出现问题,请使用双引号“”或CHR(34)将所有文本字段括在QUERY中。

以下是Adventure Works的示例查询。

-- Enclose text w/ possible commas in quotes
select 
  char(34) + AddressLine1 + char(34) as fmt_address_line1,
  char(34) + City + char(34) as fmt_city,
  PostalCode as postal_code
from 
  [AdventureWorks2012].[Person].[Address]

这应该允许您在没有任何问题的情况下在MS Excel中打开文件。