首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用Postgresql (特定数据)对字母数字进行排序?

如何使用Postgresql (特定数据)对字母数字进行排序?
EN

Stack Overflow用户
提问于 2020-04-14 02:02:47
回答 1查看 36关注 0票数 0

我很难使用postgresql对字母数字数据进行排序。我的数据和查询如下

代码语言:javascript
运行
复制
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数据也是如此)。

代码语言:javascript
运行
复制
"GPS-1"
"GPS-10"
"GPS-14"
"GPS-2"
"GPS-8A"
"GPS-8B"
"SPS-14"
"SPS-2"

我的预期结果是

代码语言:javascript
运行
复制
"GPS-1"
"GPS-2"
"GPS-8A"
"GPS-8B"
"GPS-10"
"GPS-14"
"SPS-2"
"SPS-14"

我尝试过用Alphanumeric sorting with PostgreSQLAlphanumeric sorting with PostgreSQL描述的所有解决方案,但都没有成功。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-14 02:58:48

我想你能做到的,像这样的事情:

代码语言:javascript
运行
复制
   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 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61199600

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档