按最大条件匹配排序
Posted
技术标签:
【中文标题】按最大条件匹配排序【英文标题】:Order by Maximum condition match 【发布时间】:2011-03-18 08:59:52 【问题描述】:请帮我创建一个包含 10 个“where”子句的选择查询,顺序应该是这样的: 结果应该按照匹配最多的关键字(where条件)到最不匹配的顺序显示。
注意:所有 10 个条件都带有“或”。
请帮我创建这个查询。 我正在使用 ms-sql server 2005
喜欢:
Select *
from employee
where empid in (1,2,4,332,434)
or empname like 'raj%'
or city = 'jodhpur'
or salary >5000
在上面的查询中,所有匹配最大条件的记录都应该在顶部,匹配条件较少的记录应该在底部。
【问题讨论】:
你能举一个你正在使用的查询的例子吗? 一些示例架构会有所帮助。 【参考方案1】:编辑: 这个答案是在用一个具体的例子修改问题之前发布的。 Marcelo's solution 解决了实际问题。另一方面,我的回答是优先匹配特定字段。
您可能想尝试以下类似的操作,在ORDER BY
子句中使用与WHERE
子句中相同的表达式:
SELECT *
FROM your_table
WHERE field_1 = 100 OR
field_2 = 200 OR
field_3 = 300
ORDER BY field_1 = 100 DESC,
field_2 = 200 DESC,
field_3 = 300 DESC;
我最近在 Stack Overflow 上回答了一个类似的问题,您可能有兴趣查看:
Is there a SQL technique for ordering by matching multiple criteria?【讨论】:
这里不按照匹配数排序。 是的,这是真的。最初的问题并不清楚......我想看看我是否可以调整我的答案。【参考方案2】:SELECT *
FROM (SELECT (CASE WHEN cond1 THEN 1 ELSE 0 END +
CASE WHEN cond2 THEN 1 ELSE 0 END +
CASE WHEN cond2 THEN 1 ELSE 0 END +
...
CASE WHEN cond10 THEN 1 ELSE 0 END
) AS numMatches,
other_columns...
FROM mytable
) xxx
WHERE numMatches > 0
ORDER BY numMatches DESC
【讨论】:
看起来不错,我不知道如何使用教义 + symfony 来做到这一点:D 这需要在SQL教科书中。【参考方案3】:有许多可能的选项/答案。最佳答案取决于数据的大小、非功能性要求等。
也就是说,我会做的是这样的事情(易于阅读/调试):
Select * from
(Select *, iif(condition1 = bla, 1, 0) as match1, ..... , match1+match2...+match10 as totalmatchscore from sourcetable
where
condition1 = bla or
condition2 = bla2
....) as helperquery
order by helperquery.totalmatchscore desc
【讨论】:
【参考方案4】:我无法让它在 Oracle 上为我工作。 如果使用 oracle,那么这个Order by Maximum condition match 是一个很好的解决方案。 使用语言特征时的大小写
【讨论】:
以上是关于按最大条件匹配排序的主要内容,如果未能解决你的问题,请参考以下文章
如何把EXCEL表中的数据进行按多个条件进行分类汇总,并统计出个数,并求和?
sql查询并新增一列,按条件排序后给这一列赋值,并满足条件按序列赋值