mysql - SQL识别两张表不同数据
问题描述
有两张1W行左右的表,需要查询有差异的行,现在的代码如下:
SELECT number, versionFROM ( SELECT a.number, b.version FROM a UNION ALL SELECT b.number, b.version FROM b) tbGROUP BY number, versionHAVING COUNT(*) = 1ORDER BY number
但是问题来了,以上代码只能查询出不同的行,但是没法显示a表中有的b表中没有的,b表中有的a表中没有的,有没有办法可以在第3列标识出来?
问题解答
回答1:按楼主意思,单表中number和version是不会重复的,两张表的number和version建一个复合索引,然后执行以下sql
SELECT a.number, a.version,’from_a’FROM awhere not exists (SELECT 1 FROM b where a.number=b.number and a.version=b.version)union allSELECT b.number, b.version,’from_b’FROM bwhere not exists (SELECT 1 FROM a where a.number=b.number and a.version=b.version)ORDER BY number;或者SELECT a.number, a.version,’from_a’from a left join b on a.number=b.number and a.version=b.versionwhere b.id is nullunion allSELECT b.number, b.version,’from_b’from a right join b on a.number=b.number and a.version=b.versionwhere a.id is nullORDER BY number;下面这个效率可能会差点回答2:
试试full join ... where a is null or b is null。比如用Postgres:
select case when a.n is null then b.n else a.n end as n, case when a.n is null then b.v else a.v end as v, case when a.n is null then ’b’ else ’a’ end as srcfrom (values(1, 2), (2, 3), (3, 4)) as a(n, v) full join (values(6, 7), (2, 3), (3, 9)) as b(n, v) using (n, v)where a.n is null or b.n is null
结果:
n | v | src---+---+----- 1 | 2 | a 3 | 4 | a 3 | 9 | b 6 | 7 | b(4 行记录)
相关文章:
1. css - html根字体设置成很大的值后, 包裹了行内元素的div莫名变高是什么原因2. 请教一个python字符串处理的问题?3. 老师,你这两条斜杠的是怎么注释的?4. java - mybatis源码分析5. 修改mysql配置文件的默认字符集重启后依然不生效6. javascript - 正则匹配字符串特定语句后的数字7. javascript - 一个前端的自我修养8. javascript - main head .intro-text{width:40%} main head{display:flex}为何无效?9. python - scrapy 处理 文章 分页的内容10. java - servlet的init方法和选择Filter的init方法来加载配置文件,二者有何区别?

网公网安备