SQL 查找两表中不同的数据

2022-09-23 09:04

设a表1,2,31,2,4b表1,2,31,2,41,2,5目的找出1,2,5数据量很大要效率高的语句
2022-09-23 12:11
--一句SQL就搞定
SELECT * FROM b
EXCEPT
SELECT * FROM a
更多回答
方法比较多
我随便举两个例子
假设a表中有一列‘aa’,数据是1,2,3
1,2,4
b表中有一列‘bb’,数据是1,2,3
1,2,4
1,2,5
目的是找出这个1,2,5
其实就是找出唯一值

方法1:写个子查询嵌套
select * from (select a.aa as 'ccc',b.bb as 'bbb'
from a full join b on a.aa = b.bb) c where c_ccc is null or c.bbb is null
这个语句就是找出2张表中的唯一值

方法2:利用union连接再分组having,取得唯一值
select c.aa,count(*) from (select aa from a
union all
select bb from b) c group by c.aa having count(*) = 1
查询出的就是两张表中的唯一值【其实也就是重复次数 = 1的】
热门问答