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

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

在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

最终效果

目录
相关文章
|
监控 Java 调度
Spring中的任务调度:探索@Scheduled和@Schedules注解的威力
Spring中的任务调度:探索@Scheduled和@Schedules注解的威力
590 0
|
9月前
|
人工智能 运维 资源调度
AI 赋能混合云运维:告别手工操作,迈向智能自愈!
AI 赋能混合云运维:告别手工操作,迈向智能自愈!
475 85
|
SQL 算法 数据库
OceanBase 查询优化 | 学习笔记
快速学习 OceanBase 查询优化
OceanBase 查询优化 | 学习笔记
|
11月前
|
消息中间件 存储 监控
高弹性、低成本的云消息队列RabbitMQ 版
本次课程由阿里云消息队列产品专家杨文婷分享,主题为高弹性、低成本的云消息队列RabbitMQ。内容涵盖四个方面:1) 产品优势,包括兼容开源客户端、解决稳定性痛点和高弹性低成本;2) 架构实现原理,如分布式架构和弹性调度系统;3) Serverless系列带来的按量付费模式和资源池优势;4) Serverless适用场景,如开发测试环境、峰谷流量业务等。最后解答了关于顺序消费、与普通MQ对比、自动扩容及API支持等常见问题。
411 46
|
机器学习/深度学习 人工智能 安全
元宇宙中的数字身份:重塑社交网络
在科技飞速发展的今天,元宇宙正从科幻概念变为现实。本文探讨了元宇宙中数字身份的重要性、技术基础及其对社交网络的重塑。数字身份作为连接现实与虚拟世界的桥梁,通过分布式数字身份(DID)、区块链和人工智能等技术,不仅增强了社交互动性,拓展了社交边界,还保障了用户的隐私与安全。未来,数字身份将与元宇宙深度融合,为人类带来更加丰富、多元的数字生活体验。
|
11月前
|
人工智能
阿里云领跑生成式AI工程领域,两大维度排名Gartner®生成式AI工程Market Quadrant全球第二
阿里云凭借强劲实力入选Gartner 《Innovation Guide for Generative AI Technologies》所有领域的新兴领导者象限。
|
运维 Nacos 开发者
nacos常见问题之raft报错如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
nacos常见问题之raft报错如何解决
|
大数据 数据处理 数据中心
x86和x64架构的区别及应用
x86和x64架构的区别及应用
|
Kubernetes 持续交付 开发者
使用 Docker 和 Kubernetes 实现持续集成和持续部署(CI/CD)
使用 Docker 和 Kubernetes 实现持续集成和持续部署,可以为开发团队带来更高效、稳定的交付流程。这种自动化的部署方式能够显著提高交付速度、降低发布风险,并为应用的扩展和管理提供了强大的工具。然而,构建一个完善的 CI/CD 环境需要根据团队的需求和实际情况进行调整和优化。
2493 1
使用 Docker 和 Kubernetes 实现持续集成和持续部署(CI/CD)
|
机器学习/深度学习 数据采集 人工智能
AI在戏剧与表演艺术中的应用
AI在戏剧与表演艺术中的应用
1352 0