假如我有一张表 T 其中有两列 ,如下图所示:
A | B |
1 | 3 |
1 | 3 |
2 | 5 |
2 | 4 |
3 | 7 |
3 | 7 |
其中,A列值为1的对应B列的值都为3,A列值为为2对应B列的值有两个,一个是5,一个是4,我们的目的就是列出 2 5,2 4 这两条记录。
第一种方法,巧妙的采用了max 和min函数,当我们使用A列分组后,如果 max(B)=min(B),那么B列的所有值肯定是相同的。反之则是我们需要寻找的记录。SQ如下:
select * from T where T.A in (select Ti.A from T Ti group by Ti.A having max(Ti.B)<>min(Ti.B))
也可以采用另一种写法
select * from T where T.A in (select Ti.A from (select distinct A,B from T) Ti group by Ti.A having count(Ti.B)>1
上面的写法先去除A,B当中重复的列,然后根据A列分组,计算B列不同值的个数,此方法相比较上面一种增加了一个select,复杂了一些!
不够发现可以把内部的select 去掉,简化版如下:
select * from T where T.A in (select Ti.A from Ti group by Ti.A having count(distinct Ti.B)>1
时间: 2024-10-15 14:13:38