星空网 > 软件开发 > 数据库

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

在sql server中建存储过程,如果需要参数是一个可变集合的处理

原存储过程,@objectIds 为可变参数,比如 110,98,99

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

ALTER PROC [dbo].[Proc_totalScore]

@categoryKey int,

@objectIds VARCHAR(MAX)

AS

BEGIN

     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

END

调用1:EXEC [Proc_totalScore] 99902,'110'

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

 

调用2:EXEC [Proc_totalScore] 99902,'110,97,87'

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

 

 

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

上网搜了一下大部分都是酱油贴,有网友说用

 

折中一下,用sql拼接来实现可变参数的效果 

先举个sql拼接的例子

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

DECLARE @sql NVARCHAR(MAX)

SET @sql ='select 1 mmd'

EXECUTE(@sql)

 

折中后的存储过程

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

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

最终效果

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

 




原标题:在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

关键词:sql

sql
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

七天集训:教你做出一个漂亮的独立站!(二):https://www.ikjzd.com/articles/96426
亚马逊选品背后的逻辑:https://www.ikjzd.com/articles/96431
传统外贸企业转型跨境电商?这些技巧你必须知道!:https://www.ikjzd.com/articles/96432
再不准备就晚了!父亲节选品怎么破?(下):https://www.ikjzd.com/articles/96435
什么是转口贸易?转口贸易有哪些模式区别是什么?:https://www.ikjzd.com/articles/96437
中美贸易战将持续发酵越挫越勇?:https://www.ikjzd.com/articles/96439
怪物在游轮上复活的电影 怪物在游轮上复活的电影叫什么:https://www.vstour.cn/a/411230.html
在线旅游如何选择更优惠的旅游产品?:https://www.vstour.cn/a/411231.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流