【数据库】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语句来选择去重后的前缀字符串。

相关推荐
六月闻君6 分钟前
MySQL 报错:1137 - Can‘t reopen table
数据库·mysql
SelectDB技术团队15 分钟前
兼顾高性能与低成本,浅析 Apache Doris 异步物化视图原理及典型场景
大数据·数据库·数据仓库·数据分析·doris
inventecsh31 分钟前
mongodb基础操作
数据库·mongodb
白云如幻35 分钟前
SQL99版链接查询语法
数据库·sql·mysql
爱吃烤鸡翅的酸菜鱼1 小时前
MySQL初学之旅(4)表的设计
数据库·sql·mysql·database
The_Ticker2 小时前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程
Elastic 中国社区官方博客2 小时前
Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
企鹅侠客2 小时前
ETCD调优
数据库·etcd
Json_181790144802 小时前
电商拍立淘按图搜索API接口系列,文档说明参考
前端·数据库
煎饼小狗2 小时前
Redis五大基本类型——Zset有序集合命令详解(命令用法详解+思维导图详解)
数据库·redis·缓存