工作中常会需要去对比两个表中某些数据的不同。以及关于join的操作。这里将遇到的记录一下。
比较两个表的不同
left Join 保证了左表的数据一定会存在,对于这类查Diff的场景很合适
下面这个语句可以查出来 T2中比T1新增的列与数据
key表示连接的关键值,唯一信息的那一列,例如用户ID之类
SELECT * FOROM T1
LEFT JOIN
SELECT * FROM T2
ON T1.key = T2.key
WHERE
T2.key is NULL
对于想进一步做筛选条件,可以后面加where
SELECT * FOROM T1
LEFT JOIN
SELECT * FROM T2
ON T1.key = T2.key
WHERE
T2.key is NULL OR T1.data_key != T2.data_key
Union ALL
SELECT col1, col2, col3
FROM
(
SELECT * FROM tableA
UNION ALL
SELECT * FROM tableB
) data
GROUP BY col1, col2, col3
HAVING count(*)!=2
UNION 命令只会选取不同的值,UNION ALL 会包括全部的值
鸣谢与参考:
本文近乎完全参考下文
https://www.jianshu.com/p/c7f46125d4c2
本文介绍了在数据库操作中如何比较两个表之间的差异,重点讲述了使用LEFT JOIN和UNION ALL来查找不同数据的方法。LEFT JOIN可用于找出T2中新增的记录,而UNION ALL结合GROUP BY和HAVING子句可以展示两个表中不完全相同的行。这些技巧在数据同步和差异分析场景中非常实用。
6万+

被折叠的 条评论
为什么被折叠?



