我有一个调用存储过程的BCP进程.通常,我一直在执行此存储过程并将数据复制到Excel工作表,我将所有列指定为文本并将其另存为CSV.
我需要自动完成这项工作,并且一直在使用BCP命令,但到目前为止还存在问题.我的数据中有逗号,它将数据向左移动.这是我可以用格式文件或类似的东西克服的吗?
我宁愿不在proc本身的输出中引用它们.
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中打开文件.