0

我编写了一个存储过程,它从多个表中构建一个字符串,然后返回它。它可以从 SSMS 完美运行,SP 是从第三方软件调用的,它没有返回正确的值。

SP 的重点是生成对文件所做更改的资产标签。sp低于

ALTER PROCEDURE [dbo].[usp_ACREpdflibTAG] -- 在此处添加存储过程的参数 @SJID INT AS BEGIN DECLARE @Asset VARCHAR(2000) SET ANSI_NULLS OFF

SELECT @Asset = COALESCE(@Asset, '') + { fn CONCAT(tPdfChanges.ShortHand, '=1,') } 从 tPdfChanges WHERE SubJobID = @SJID

声明 @AssetTag VARCHAR(4000)

SET @AssetTag = (SELECT 
'@@@AssetTagStart@@@' + 
@Asset
+ 'Desc=' + a.sName
+ ',UPC=' + h.sBarcodeStd
+ ',Cat=' + CAST(b.GACategoryID AS VARCHAR(10))
+ ',Type=' + CAST(d.GAProductTypeID AS VARCHAR(10))
+ ',PackFormat=' + CAST(f.GAPackTypeID AS VARCHAR(10))
+ ',DispDate=' + ISNULL(CONVERT ( varchar  , g.DCompleted ,105 ), '')
+ '@@@AssetTagEnd@@@'
FROM
tSubJob a   
WHERE
a.ID = @SJID)


select @AssetTag
END

我不得不从查询中删除表名,因为它们对我工作的业务很敏感。

从 SSMS 运行时,将返回以下内容:

@@@AssetTagStart@@@CutChg=1,DesChg=1,UPCChg=1,ProChg=1,IngChg=1,NutChg=1,StoreChg=1,CookChg=1,TtlChg=1,LegChg=1,AgyChg=1,WeightChg=1,CountryChg=1,ImpChg=1,OtherChg=1,Desc=Testing Triggers,UPC=,Cat=27,Type=3,PackFormat=38,DispDate=25-07-2012@@@AssetTagEnd@@@

当第三方软件执行它时,将返回以下内容:

@@@AssetTagStart@@@CutChg=1,Desc=Testing Triggers,UPC=,Cat=27,Type=3,PackFormat=38,DispDate=25-07-2012@@@AssetTagEnd@@@

如您所见,它仅匹配资产标签第一部分中的一个更改。

我使用分析器查看发生了什么,当我从 SSMS 执行它时,它是一个 RPC,当它从第三方软件执行时,它是一个 SQL Batch 查询。

任何人都可以帮忙吗?

4

1 回答 1

0

我自己刚刚解决了这个问题,我查看了分析器中的进程 ID,进一步向上看,第三方软件将行数设置为 1,我重置了它,一切正常。

于 2012-07-26T09:46:13.787 回答