【数据库】PostgreSQL中使用`SELECT DISTINCT`和`SUBSTRING`函数实现去重查询
在PostgreSQL中,我们可以使用SELECT DISTINCT
和SUBSTRING
函数来实现对某个字段进行去重查询。本文将介绍如何使用这两个函数来实现对resource_version
字段的去重查询。
1. SELECT DISTINCT
语句
SELECT DISTINCT
语句用于从表中选择不重复的记录。如果没有指定列名,则会选择所有列。在本例中,我们将使用SELECT DISTINCT
语句来选择去重后的resource_version
字段值。
SELECT DISTINCT resource_version
FROM tb_resource;
2. SUBSTRING
函数
SUBSTRING
函数用于从字符串中提取子串。它有三个参数:原始字符串、起始位置和子串长度。在本例中,我们将使用SUBSTRING
函数来截取每个resource_version
字段值的前N个字符,其中N为第4个.
之后的字符数。
SELECT DISTINCT substring(resource_version, 0, position(split_part(resource_version,'.',4) in resource_version)-1)
FROM tb_resource;
3. 结合使用SELECT DISTINCT
和SUBSTRING
函数
有时候我们需要同时使用SELECT DISTINCT
和SUBSTRING
函数来进行更复杂的文本操作。在本例中,我们将使用这两个函数来实现对每个resource_version
字段值的前3个字符进行去重查询。
SELECT DISTINCT substring(resource_version, 0, position(split_part(resource_version,'.',4) in resource_version)-1)
FROM tb_resource;
以上代码中,我们首先使用position(split_part(resource_version,'.',4) in resource_version)-1
获取第4个.
之前的字符数,然后使用该值作为子串长度来截取每个resource_version
字段值的前N个字符。最后,我们使用SELECT DISTINCT
语句来选择去重后的前缀字符串。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)