SQL:我想在X表select出X,Y表中A列相同前提下对应的B列不存在Y表B列的记录

X表
A B
1 1
1 2
1 3
2 2
2 3
2 4

Y表
A B
1 1
1 2
1 4
2 3
2 4
2 5

我想选择得出的结果是:
A B
1 3
2 2

1、你的问题问的有问题,按照你的问题5楼的回答是正确的。
2、但是看到你的结果集,5楼的回答是错的。
正确答案是:
select a,*
from X a
left join Y b on a.A=b.A and a.B=b.B
where b.A is null

select X.A from X,Y where X.A=Y.A

如果两列的话
select X.* from X,Y where X.A=Y.A and X.B=Y.B;

select X.* from X,Y where X.A = Y.A ;

 select X.* from X,Y where X.A = Y.A and X.B != Y.B;
select X.* from X,Y where X.A = Y.A and X.B not in (select Y.B from Y); 

图片说明sqlserver

在MySQL中,六楼的回答能够得到你想要的结果集,在sqlserver中六楼和七楼的回答能够得到你想要的结果集