当前位置: 首页 > news >正文

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

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

1、解决方法一

SELECT t1.*
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.tid

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

2、解决方法二

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、解决方法三

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

4、其他补充

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

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

http://www.lryc.cn/news/248516.html

相关文章:

  • Golang与MongoDB的完美组合
  • 初识Java 18-2 泛型
  • vue分环境打包及案例代码
  • 基于springboot+vue的在线考试系统(前后端分离)
  • 重装linux后需要做的配置
  • 【华为数通HCIP | 网络工程师】821刷题日记-IS-IS(2)
  • Linux系统-----进程管理(进程的创建与控制)
  • Unity 获取物体的子物体的方法
  • RocketMQ 读写压测
  • PHP调用API接口的方法及实现(一键采集淘宝商品详情数据)
  • 得物App安卓冷启动优化-Application篇
  • 【实战教程】PHP与七牛云的完美对接
  • Go 接口:nil接口为什么不等于nil?
  • (UM1724) STM32 Nucleo-64 boards User manual
  • SourceInsight - Relation Windows
  • 二维数组处理
  • 线性表——(2)线性表的顺序存储及其运算的实现
  • 数据结构 -- 图论之最小生成树
  • 【已解决】游戏缺少xinput1_3.dll的详细解决方案与详情解析
  • 华天动力-OA8000 MyHttpServlet 文件上传漏洞复现
  • 小航助学题库蓝桥杯题库c++选拔赛(23年8月)(含题库教师学生账号)
  • [Ubuntu 18.04] RK3399搭建NFS服务实现共享目录
  • Java---抽象类讲解
  • CNAS认可是什么?CNAS软件测试报告如何获取?
  • Tomcat 修改版本号
  • Python算法——霍夫曼编码树
  • hql面试题之上海某资深数仓开发工程师面试题-求不连续月份的月平均值
  • VT驱动开发
  • 火柴人版王者-Java
  • docker 中的–mount 和-v 参数有啥区别