博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?
阅读量:5970 次
发布时间:2019-06-19

本文共 1238 字,大约阅读时间需要 4 分钟。

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

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

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

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

 

调用2EXEC [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

最终效果

 

转载于:https://www.cnblogs.com/dunitian/p/4501268.html

你可能感兴趣的文章
中国发布自主开发的域名系统基础软件 “红枫”
查看>>
优秀程序员必须知道的32个算法,提高你的开发效率
查看>>
在WPF中实现平滑滚动
查看>>
java并发编程实践 part 01 --&gt; 线程创建方式
查看>>
crontab+php-cgi/php 定时执行PHP脚本
查看>>
中小型互联网企业安全建设漫谈。
查看>>
建筑论文发表流程
查看>>
jdk5.0新特性—— 枚举
查看>>
IOS开发常见warning汇总
查看>>
[Curator] Path Cache 的使用与分析
查看>>
什么是软件外包
查看>>
Delphi字符串函数Delete
查看>>
Ubuntu14.04 + Matlab2014a + caffe + cuda + cudnn环境搭建
查看>>
CCNA-EiGrp学习
查看>>
一些简单的编程练习题
查看>>
Video4Linux2 part 2: registration and open()
查看>>
12.10 Nginx访问日志 12.11 Nginx日志切割 12.12 静态文件不记录日志和过期时间
查看>>
Vim命令之查找和替换
查看>>
tar time stamp in the future 报错 解决方案
查看>>
计算节点宕机了怎么办?- 每天5分钟玩转 OpenStack(43)
查看>>