在SQL Server中的BCP实用程序的查询语法中使用varchar

时间:2014-02-20 02:19:56

标签: sql-server tsql bcp

我正在尝试使用BCP实用程序使用这些命令导出数据,但我在查询中出错...

我声明了很多变量,但我的问题在于查询,因为我必须使用varchar列进行过滤(CO_LINvarchar(6)),但如果我使用'包装变量@LINEAPRODUCTO的值我在SQL Server查询工具中遇到错误,但是如果我不使用任何东西它会给我这个错误:

  

无效的列名称'MEN'

MEN是我在变量声明中设置的字符串值)

DECLARE @PATH_ARC VARCHAR(200)
DECLARE @USUARIO VARCHAR(20)
DECLARE @PASSWORD VARCHAR(20)
DECLARE @TABLA VARCHAR(40)
DECLARE @SERVIDOR VARCHAR(100)
DECLARE @ARCHIVOSALIDA VARCHAR(200)
DECLARE @RUTAEJECUTAR VARCHAR(500)
DECLARE @MES VARCHAR(2)
DECLARE @DIA VARCHAR(2)
DECLARE @ANNO VARCHAR(4)
DECLARE @BASEDEDATOS VARCHAR(20)
DECLARE @LINEAPRODUCTO VARCHAR(6)
DECLARE @CONSULTA VARCHAR(300)

SET NOCOUNT ON;

-- Asignación de valores de las variables para la ejecución del stored procedure
SET @TABLA ='dbo.art'
SET @SERVIDOR = 'RJLD-LAPTOP\SQLEXPRESS'
SET @USUARIO = 'exp'
SET @PASSWORD = 'exp'
SET @PATH_ARC = 'C:\PRUEBA\'
SET @BASEDEDATOS = 'DEMO'
SET @LINEAPRODUCTO = 'MEN'

SET @MES = CAST(MONTH(GETDATE()) AS nchar(2))

IF LEN(RTRIM(LTRIM(@MES))) = 1
BEGIN
   SET @MES = '0' + RTRIM(LTRIM(@MES))
END

SET @DIA = CAST(DAY(GETDATE()) AS nchar(2))

IF LEN(RTRIM(LTRIM(@DIA))) =1
BEGIN
    SET @DIA = '0' + RTRIM(LTRIM(@DIA))
END

SET @ANNO = CAST(YEAR(GETDATE()) AS nchar(4))
SET @ARCHIVOSALIDA = 'RI_C58-L02_' + @ANNO  + @MES + @DIA + '.txt'
SET @PATH_ARC = '"' +  @PATH_ARC + @ARCHIVOSALIDA + '"'
SET @CONSULTA = '"select RTRIM(LTRIM(ITEM)),' + @ANNO + ',' +  @MES + ',' + @DIA + ',CO_PROV from ' + @TABLA + ' WHERE CO_LIN=' + @LINEAPRODUCTO + '"'

SET @RUTAEJECUTAR = 'bcp ' +  @CONSULTA + ' queryout ' + @PATH_ARC + ' -S ' + @SERVIDOR + ' -U ' + @USUARIO + ' -P ' + @PASSWORD + ' -c -t "|" -d ' +  @BASEDEDATOS

--  select @RUTAEJECUTAR
EXEC xp_cmdshell @RUTAEJECUTAR   

1 个答案:

答案 0 :(得分:0)

我不熟悉BCP实用程序,但我看到的情况与我在StackOverflow使用的代码格式中看到的情况相同。注意PRUEBA之后的斜杠是如何导致下面的撇号无法识别的。我发现了另一个问题here,其中有人不得不使用斜杠作为转义符来绕过BCP实用程序。

如果文件路径中的斜杠正在注册为转义字符,则以下代码应该有效:

SET @PATH_ARC = 'C:\\PRUEBA\\'
SET @BASEDEDATOS = 'DEMO'
SET @LINEAPRODUCTO = 'MEN'

请注意,使用上面的代码,StackOverflow格式也正确地读取它。

希望这有帮助!