PostgreSQL-SQL联表查询LEFT JOIN 数据去重复

我们在使用left join联表查询时,如果table1中的一条记录对应了table2的多条记录,则会重复查出id相同的多条记录。

1、解决方法一

sql 复制代码
SELECT t1.*
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.tid

第一种方法我们发现还是有重复数据

2、解决方法二

sql 复制代码
SELECT tmp.id, max(tmp.name) FROM (
SELECT t1.*
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.tid
) tmp group by tmp.id

3、解决方法三

sql 复制代码
SELECT distinct tmp.id, tmp.name FROM (
SELECT t1.*
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.tid
) tmp

4、其他补充

我们需要查询重复的行的总行数,可以进行如下操作:

sql 复制代码
SELECT tmp.id, count(tmp.name) as count FROM (
SELECT t1.*
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.tid
) tmp group by tmp.id order by id asc
相关推荐
m0_7066532310 分钟前
开源键值存储数据库如何实现微秒级响应
数据库
小宇的天下10 分钟前
Calibre LVS Circuit Comparison(1)
linux·数据库·lvs
羊小猪~~17 分钟前
【QT】-- 模型与视图简介
开发语言·数据库·c++·后端·qt·前端框架·个人开发
荒川之神34 分钟前
ORACLE 参数文件损坏恢复实例
数据库·oracle
拂晓神剑zzz35 分钟前
Neo4j图数据库
数据库·neo4j
鬼蛟43 分钟前
Redis
数据库·redis·缓存
Ricky_Theseus1 小时前
SPOOLING 系统详解
linux·服务器·数据库
HUGu RGIN1 小时前
Redis 下载与安装 教程 windows版
数据库·windows·redis
卢光庆1 小时前
aardio - wsock.tcp.simpleHttpServer 访问数据库例程
数据库
木心术11 小时前
OpenClaw数据库自动化部署与网站接口调通全流程指南
运维·数据库·自动化