我正在处理一个SQL查询,它将值列表作为参数传递,如
构建连接可以在msSQL查询编辑器中运行并运行它,但是…… @H_403_4@由于将查询发送到mssql的软件的限制,我必须将其作为1参数传递给某个内部查询构建器,因此“24,65”.我不知道这个列表中会有多少个数字,可能是2,可能是20.
select * from ProductGroups where GroupID in (24,12,7,14,65)@H_403_4@此列表由通过数据库使用的关系构成,并且必须按此顺序保存. @H_403_4@我想按此列表订购结果.我只需要第一个结果,但在这种情况下它可能是GroupId 7的结果. @H_403_4@我不能查询
order by (24,65).indexOf(GroupId)@H_403_4@有谁知道如何做到这一点? @H_403_4@附加信息:
构建连接可以在msSQL查询编辑器中运行并运行它,但是…… @H_403_4@由于将查询发送到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