Postgresql排序混合的字母数字数据

前端之家收集整理的这篇文章主要介绍了Postgresql排序混合的字母数字数据前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
运行此查询
select name from folders order by name

返回以下结果:

alphanumeric
a test
test 20
test 19
test 1
test 10

但我预计:

a test
alphanumeric
test 1
test 10
test 19
test 20

这有什么不对?

如果有尾随数字,您可以通过拆分文本来手动排序,如下所示:
SELECT * FROM sort_test
ORDER BY SUBSTRING(text FROM '^(.*?)( \\d+)?$'),COALESCE(SUBSTRING(text FROM ' (\\d+)$')::INTEGER,0);

这将对列文本进行排序,首先是所有字符,可选地排除结尾空格后跟数字,然后排除那些可选数字.

在我的测试中工作得很好.

Update使用简单的合并(duh)修复了仅字符串排序.

原文链接:https://www.f2er.com/postgresql/192313.html

猜你在找的Postgre SQL相关文章