作者:无棱9931 | 来源:互联网 | 2023-01-27 14:16
我正在尝试编写一个查询,该查询将一些结果(在我的情况下为单个结果)放在顶部,然后对其余结果进行排序。我尚未找到PostgreSQL解决方案。
说我有一个airports
像这样的桌子。
id | code | display_name
----+------+----------------------------
1 | SDF | International
2 | INT | International Airport
3 | TES | Test
4 | APP | Airport Place International
简而言之,我在控制器方法中有一个查询,当用户文本通过code
或搜索机场时,该查询将被异步调用display_name
。但是,当用户输入的输入code
完全匹配时(机场代码是唯一的),我希望该结果首先出现,然后所有int
在其中也要display_name
升序显示的机场。如果不存在完全匹配项,则应返回所有按display_name
升序排序的通配符匹配项。因此,如果用户输入INT
,(2, INT, International Airport)
则应首先返回该行,然后再返回其他行:
Results:
1. INT | International Airport
2. APP | Airport Place International
3. SDF | International
这是我正在修改的查询的一种,它在我的应用程序上下文之外进行了稍微简化以使其有意义,但是仍然具有相同的概念。
SELECT * FROM airports
WHERE display_name LIKE 'somesearchtext%'
ORDER BY (CASE WHEN a.code = 'somesearchtext` THEN a.code ELSE a.display_name END)
现在,如果输入,结果INT
就是
Results:
1. APP | Airport Place International
2. INT | International Airport
3. SDF | International
我ORDER BY
必须是不正确的,但我似乎无法得到它。任何帮助将不胜感激:)
1> Gordon Linof..:
如果您希望完全匹配code
首先返回,那么我认为这可以解决问题:
SELECT a.*
FROM airports a
WHERE a.display_name LIKE 'somesearchtext%'
ORDER BY (CASE WHEN a.code = 'somesearchtext' THEN 1 ELSE 2 END),
a.display_name
您也可以这样写:
ORDER BY (a.code = 'somesearchtext') DESC, a.display_name
这不是标准的SQL,但可读性强。