说我有这样的查询:
SELECT X FROM Table WHERE Y = 'Z'
如何使用上述查询中的每个X
作为参数执行存储过程?
更新
我已将SP更改为表值函数。因此,对于函数的每次调用,它将返回一个表。我需要做的是将所有这些结果存储在临时表中,让我的SP返回此表。
解
最后设法在@cyberkiwi的帮助下使用它。这是我的最终解决方案:
DECLARE @Fields TABLE (
Field int)
INSERT INTO @Fields (X) SELECT * FROM tvf_GetFields(@SomeIdentifier)
SELECT * FROM @Fields
CROSS APPLY dbo.tvf_DoSomethingWithEachField([@Fields].Field)
答案 0 :(得分:8)
您可以从中生成批处理语句,然后执行它
DECLARE @sql nvarchar(max)
SELECT @sql = coalesce(@sql + ';', '')
+ 'exec sprocname ' + QuoteName(AField, '''')
FROM Table
WHERE AField2 = 'SomeIdentifier'
AND AField is not null
EXEC (@sql)
在编辑之前(到TVF),您可以更改SP以继续填充临时表。
对TVF进行编辑后,您可以使用交叉申请:
SELECT F.*
FROM Tbl CROSS APPLY dbo.TVFName(Tbl.AField) F
WHERE Tbl.AField2 = 'SomeIdentifier'
将每次调用Tbl.AField的所有“表结果”返回到单个结果集