首页 > 解决方案 > BCP 实用程序 SQL Server 导出到 CSV - 永远不会创建目标 CSV 文件

问题描述

bcp在 SQL Server 2017 中使用该实用程序时遇到以下错误。

我需要.CSV使用逗号作为列分隔符将数据从 SQL Server 中的视图导出到文件。我的数据在某些列中包含逗号。所以我在使用 . 创建视图时使用 " 作为列限定符[+'"' column_name + '"']

我尝试了 3 种不同的方法:

选项1:

declare @sql varchar(8000)
select @sql = 'bcp "SELECT * FROM MyDB.dbo.MyTable
          WHERE Rn BETWEEN 1 AND 100 ORDER BY Rn"
       queryout "E:\MyFolder\MyFileName.txt" -c -t, -T -S' + @@servername 
exec master..xp_cmdshell @sql

选项 2:

declare @sql varchar(8000)
select @sql = 'bcp "SELECT * FROM MyDB.dbo.MyTable
          WHERE Rn BETWEEN 1 AND 100 ORDER BY Rn"
       queryout "E:\MyFolder\MyFileName.txt" -c -t, [MyServer_Name] -T -S'
exec master..xp_cmdshell @sql

选项 3

   declare @sql varchar(8000)
   select @sql = 'bcp "SELECT * FROM MyDB.dbo.MyTable
              WHERE Rn BETWEEN 1 AND 100 ORDER BY Rn"
           queryout "E:\MyFolder\MyFileName.txt" -c -t, [MyServer_Name] -T -S ' + '@@servername' 
   exec master..xp_cmdshell @sql

在每种情况下,我都会得到相同的输出,但 CSV 文件永远不会被创建:

usage: bcp {dbtable | query} {in | out | queryout | format} datafile
  [-m maxerrors]            [-f formatfile]          [-e errfile]
  [-F firstrow]             [-L lastrow]             [-b batchsize]
  [-n native type]          [-c character type]      [-w wide character type]
  [-N keep non-text native] [-V file format version] [-q quoted identifier]
  [-C code page specifier]  [-t field terminator]    [-r row terminator]
  [-i inputfile]            [-o outfile]             [-a packetsize]
  [-S server name]          [-U username]            [-P password]
  [-T trusted connection]   [-v version]             [-R regional enable]
  [-k keep null values]     [-E keep identity values]
  [-h "load hints"]         [-x generate xml format file]
  [-d database name]        [-K application intent]  [-l login timeout]
  NULL

PS.CSV :我找到了从 SQL Server导入数据的替代解决方案。但这里的问题是sqlcmd- 不像bcp- 不接受两个字符作为文本限定符。我决定使用~^逗号后面的 2 个字符的文本限定符作为字段分隔符。

 exec master..xp_cmdshell 'sqlcmd -s -W -Q "set nocount on;select * from MyTable" | findstr /v /c:"-" /b > "E:\MyFile.csv"' 

-scol_separator在哪里

指定列分隔符。默认为空格。此选项设置 sqlcmd 脚本变量 SQLCMDCOLSEP。要使用对操作系统具有特殊含义的字符,例如与号 (&) 或分号 (;),请将字符括在引号 (") 中。列分隔符可以是任何 8 位字符。( https:/ /docs.microsoft.com/en-us/sql/tools/sqlcmd-utility?view=sql-server-ver15 )

标签: sql-servercsvexport-to-csvbcp

解决方案


提供给的命令行xp_cmdshell不能跨越多行文本,它们需要在一行中完全指定。尝试将命令构建为一系列连接的字符串,如下所示:

declare @sql varchar(8000) =
    'bcp' +
    ' "select * from MyDB.dbo.MyTable WHERE Rn BETWEEN 1 AND 100 order by Rn"' +
    ' queryout' +
    ' "E:\MyFolder\MyFileName.txt"' +
    ' -c -t, -T -S' + @@servername 
exec master..xp_cmdshell @sql

连接字符串时,请注意您需要在每个段之间包含空格的位置,以便命令行参数不会相互冲突。


推荐阅读