我正在尝试使用BCP实用程序使用这些命令导出数据,但我在查询中出错...
我声明了很多变量,但我的问题在于查询,因为我必须使用varchar列进行过滤(CO_LIN
是varchar(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
答案 0 :(得分:0)
我不熟悉BCP实用程序,但我看到的情况与我在StackOverflow使用的代码格式中看到的情况相同。注意PRUEBA之后的斜杠是如何导致下面的撇号无法识别的。我发现了另一个问题here,其中有人不得不使用斜杠作为转义符来绕过BCP实用程序。
如果文件路径中的斜杠正在注册为转义字符,则以下代码应该有效:
SET @PATH_ARC = 'C:\\PRUEBA\\'
SET @BASEDEDATOS = 'DEMO'
SET @LINEAPRODUCTO = 'MEN'
请注意,使用上面的代码,StackOverflow格式也正确地读取它。
希望这有帮助!