首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >替换和转换字符串- Postgresql

替换和转换字符串- Postgresql
EN

Stack Overflow用户
提问于 2016-01-12 02:11:20
回答 1查看 2.1K关注 0票数 0

我需要从一个名为序列的列中选择最大值,这是varchar。值列为1-1,1-2,1-3,2-1,2-2,2-3,3-1,3-2,3-3等。我如何删除"-“(必要时转换为int )才能使用最大特征?当前,尝试选择max(序列)返回所有记录。

代码语言:javascript
运行
复制
SELECT MAX(regexp_replace(Sequence, '-', '')), Policy
FROM Transactions
WHERE Policy = '1234'
GROUP BY Policy

引发以下错误:

错误42S02错误:函数'REGEXP_REPLACE(VARCHAR,未知,未知)‘不存在,无法识别满足您可能需要添加显式类型的参数类型的函数*/

示例表:

预期结果:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-12 02:17:41

也许您可以只使用字符串最大值:

代码语言:javascript
运行
复制
SELECT MAX(Sequence), Policy
FROM Transactions
WHERE Policy = '1234'
GROUP BY Policy;

这适用于所提供的数据。如果它不能工作,因为您有类似于'1-10'的值,那么您可以将其转换为浮点数或十进制:

代码语言:javascript
运行
复制
SELECT MAX(REPLACE(Sequence, '-', '.')::numeric), Policy
FROM Transactions
WHERE Policy = '1234'
GROUP BY Policy;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34734480

复制
相关文章

相似问题

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