在sql server中建存儲過程,若是須要參數是一個可變集合的處理sql
原存儲過程,@objectIds 爲可變參數,好比 110,98,99spa
ALTER PROC [dbo].[Proc_totalScore]server
@categoryKey int,xml
@objectIds VARCHAR(MAX)blog
ASobject
BEGINselect
SELECT c.Name,AVG(e.Score) Score FROM dbo.Sys_com_comment_main mim
INNER JOIN dbo.sys_com_coment_extend e ON e.commentId=m.ID存儲過程
INNER JOIN dbo.sys_com_category c ON e.NameKey=c.NameKeydb
WHERE m.categoryKey=@categoryKey AND m.dataStatus<>99 AND m.IsCheck=0 AND m.objectId IN(@objectIds)
GROUP BY c.Name
END
調用1:EXEC [Proc_totalScore] 99902,'110'
調用2:EXEC [Proc_totalScore] 99902,'110,97,87'
在sql server中建存儲過程,若是須要參數是一個可變集合怎麼處理?
上網搜了一下大部分都是醬油貼,有網友說用xml的方式,具體的代碼也沒看見
折中一下,用sql拼接來實現可變參數的效果
先舉個sql拼接的例子
DECLARE @sql NVARCHAR(MAX)
SET @sql ='select 1 mmd'
EXECUTE(@sql)
折中後的存儲過程
ALTER PROC [dbo].[Proc_totalScore]
@categoryKey VARCHAR(100),
@objectIds VARCHAR(MAX)
AS
BEGIN
DECLARE @sql NVARCHAR(MAX)
SET @sql ='SELECT c.Name,AVG(e.Score) Score FROM dbo.Sys_com_comment_main m
INNER JOIN dbo.sys_com_coment_extend e ON e.commentId=m.ID
INNER JOIN dbo.sys_com_category c ON e.NameKey=c.NameKey
WHERE m.categoryKey='+@categoryKey+' AND m.dataStatus<>99 AND m.IsCheck=0 AND m.objectId IN('+@objectIds+')
GROUP BY c.Name'
EXECUTE(@sql)
END
最終效果