我很难使用postgresql对字母数字数据进行排序。我的数据和查询如下
WITH x(t) AS (
VALUES
('GPS-10')
,('GPS-1')
,('GPS-2')
,('GPS-8B')
,('GPS-8A')
,('GPS-14')
,('SPS-2')
,('SPS-14')
)
SELECT t
FROM x
ORDER BY substring(t, '[^0-9-].*$'), (substring(t, '^[0-9]+'))::int
它给了我错误的结果(GPS-2出现在GPS-10和GPS-14之后,SPS数据也是如此)。
"GPS-1"
"GPS-10"
"GPS-14"
"GPS-2"
"GPS-8A"
"GPS-8B"
"SPS-14"
"SPS-2"
我的预期结果是
"GPS-1"
"GPS-2"
"GPS-8A"
"GPS-8B"
"GPS-10"
"GPS-14"
"SPS-2"
"SPS-14"
我尝试过用Alphanumeric sorting with PostgreSQL和Alphanumeric sorting with PostgreSQL描述的所有解决方案,但都没有成功。
发布于 2020-04-14 02:58:48
我想你能做到的,像这样的事情:
WITH x(t) AS (
VALUES
('GPS-10')
,('GPS-1')
,('GPS-2')
,('GPS-8B')
,('GPS-8A')
,('GPS-14')
,('SPS-2')
,('SPS-14')
)
SELECT t
FROM x
ORDER BY substring(t, 1,3), (substring(substring(t, 5, length(t)), '^[0-9]+'))::int
https://stackoverflow.com/questions/61199600
复制相似问题