【数据库】PostgreSQL中使用`SELECT DISTINCT`和`SUBSTRING`函数实现去重查询

在PostgreSQL中,我们可以使用SELECT DISTINCTSUBSTRING函数来实现对某个字段进行去重查询。本文将介绍如何使用这两个函数来实现对resource_version字段的去重查询。

1. SELECT DISTINCT语句

SELECT DISTINCT语句用于从表中选择不重复的记录。如果没有指定列名,则会选择所有列。在本例中,我们将使用SELECT DISTINCT语句来选择去重后的resource_version字段值。

sql 复制代码
SELECT DISTINCT resource_version
FROM tb_resource;

2. SUBSTRING函数

SUBSTRING函数用于从字符串中提取子串。它有三个参数:原始字符串、起始位置和子串长度。在本例中,我们将使用SUBSTRING函数来截取每个resource_version字段值的前N个字符,其中N为第4个.之后的字符数。

sql 复制代码
SELECT DISTINCT substring(resource_version, 0, position(split_part(resource_version,'.',4) in resource_version)-1)
FROM tb_resource;

3. 结合使用SELECT DISTINCTSUBSTRING函数

有时候我们需要同时使用SELECT DISTINCTSUBSTRING函数来进行更复杂的文本操作。在本例中,我们将使用这两个函数来实现对每个resource_version字段值的前3个字符进行去重查询。

sql 复制代码
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语句来选择去重后的前缀字符串。

相关推荐
七度黑光2 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
华科易迅3 小时前
Spring 事务(注解)
java·数据库·spring
Java面试题总结3 小时前
MySQL篇 索引失效
数据库·mysql
last demo3 小时前
mysql
运维·数据库·mysql·oracle
kevin_cat5 小时前
oracle 扩展表空间
数据库·oracle
花间相见5 小时前
【MySQL面试题】—— MySQL面试高频问题汇总:从原理到实战,覆盖90%考点
数据库·mysql·面试
高梦轩6 小时前
MySQL 数据库备份与恢复
数据库·oracle
一直都在5726 小时前
Redis(二)
数据库·redis·缓存
TDengine (老段)6 小时前
TDengine IDMP 工业数据建模 —— 属性
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
爱丽_7 小时前
Redis 分布式锁:SET NX、过期时间、续租、可重入、Redlock 与坑
数据库·redis·分布式