数组 – 从Postgres字符串获取最后一个字,以声明方式

这个问题的[编辑]原始标题是“获取Postgres数组的最后一个元素,以声明方式”

如何获取Postgres中数组的最后一个元素?

我需要以声明方式做,因为我想使用它作为ORDER BY标准.我不想为它创建一个特殊的PGsql函数,在这种情况下对数据库的更改越少越好.

事实上,我想做的是按照包含多个单词的特定列的最后一个单词排序.改变模型不是一个选择.

换句话说,我想推送Ruby的sort_by {| x | x.split [-1]}到数据库级别.我可以用Postgres string_to_array或regexp_split_to_array函数将值分割成数组,然后如何获取最后一个元素?

如果我正确地理解你的问题,你有一个字符串,你首先在某个分隔符上拆分它,然后找到数组的最后一个元素,并丢弃其余的元素.

你可以错过中间人,直接得到最后一个元素:

SELECT regexp_replace('foo bar baz','^.* ','')

结果:

baz

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...