sql-server – 按值列表排序查询结果
发布时间:2021-03-17 02:15:37 所属栏目:MsSql教程 来源:网络整理
导读:我正在处理一个sql查询,它将值列表作为参数传递,如 select * from ProductGroupswhere GroupID in (24,12,7,14,65) 此列表由通过数据库使用的关系构成,并且必须按此顺序保存. 我想按此列表订购结果.我只需要第一个结果,但在这种情况下它可能是GroupId 7的结果
我正在处理一个sql查询,它将值列表作为参数传递,如 select * from ProductGroups where GroupID in (24,12,7,14,65) 此列表由通过数据库使用的关系构成,并且必须按此顺序保存. 我想按此列表订购结果.我只需要第一个结果,但在这种情况下它可能是GroupId 7的结果. 我不能查询 order by (24,65).indexOf(GroupId) 有谁知道如何做到这一点? 附加信息: 由于将查询发送到mssql的软件的限制,我必须将其作为1参数传递给某个内部查询构建器,因此“24,65”.我不知道这个列表中会有多少个数字,可能是2,可能是20. 解决方法使用带有标识列的表变量或临时表,输入您的值并加入其中,例如declare @rank table ( ordering int identity(1,1),number int ) insert into @rank values (24) insert into @rank values (12) insert into @rank values (7) insert into @rank values (14) insert into @rank values (65) select pg.* from ProductGroups pg left outer join @rank r on pg.GroupId = r.number order by r.ordering (编辑:应用网_常德站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 数据库设计 – 轮询是从数据库更新应用程序数据的唯一方法吗
- sql-server – 为什么我需要两个SQL Server Service Broker
- SQL数据库备份怎样做?数据库备份代码解析
- SQL Server异常处理怎么样做?
- sql-server – 域更改后无法连接SQL Management Studio
- SQL事件探查器可以在查询旁边显示返回结果集吗?
- sql-server – SQL Server使用与定义不匹配的数据填充PERSI
- sql – 如何使用Excel VBA获取新插入记录的ID?
- sql-server – 在专用数据库服务器上,为操作系统保留多少内
- sql – 将SELECT行压缩成字符串的最佳方法是什么?
站长推荐
热点阅读