我编写了一个存储过程,它从多个表中构建一个字符串,然后返回它。它可以从 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 查询。
任何人都可以帮忙吗?