exists (返回结果集,为真)
not exists (不返回结果集,为真)
表A
ID NAME
1 A1
2 A2
3 A3
表B
ID AID NAME
1 1 B1
2 2 B2
3 2 B3
表A和表B是1对多的关系 A.ID => B.AID
1.SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE A.ID = B.AID);
执行结果:
ID NAME
1 A1
2 A2
原理如下:
(1)SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=1)
---> SELECT * FROM B WHERE B.AID=1有值,返回真,所以有数据
(2)SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=2)
---> SELECT * FROM B WHERE B.AID=2有值,返回真,所以有数据
(3)SELECT ID,NAME FROM A WHERE EXISTS (SELECT * FROM B WHERE B.AID=3)
---> SELECT * FROM B WHERE B.AID=3无值,返回假,所以没有数据
得到的结果为,A.ID=1或2时才有数据,所以最终的条件等于
SELECT ID,NAME FROM A where id in (1,2);
扩展:
SELECT A.ID AID,A.NAME A_NAME,B.ID BID,B.AID B_AID,B.NAME B_NAME FROM A,B WHERE A.ID = B.AID;
多表关联时,是将相关联的记录拼合到一起,而非多次拼合(而当两张表是相同的表是,会多次拼合)
2. 同时,我们也可以作用于多个列
在某张表中,有A->B冲突,同时B->A冲突的记录(重复记录),我们以sid (1)找到A<->B的记录对 select distinct * from C C1,C C2 WHERE C1.SID =C2.TID AND C1.TID = C2.SID; (切记去重) (2)找到其中sid>tid的记录 select distinct C1.SID,C1.TID from C C1,C C2 WHERE C1.SID =C2.TID AND C1.TID = C2.SID and C1.SID > C1.TID (3)删除这些记录 DELETE C WHERE EXISTS ( 此时在c表中删除的就是c.sid和c.tid符合这个条件的记录了create table C(
sid number,
tid number
)
insert into c values (1,2);
insert into c values (2,1);
insert into c values (2,3);
insert into c values (3,2);
insert into c values (3,4);
insert into c values (4,3);
insert into c values (5,6);
select distinct C1.SID,C1.TID from C C1,C C2 WHERE C1.SID =C2.TID AND C1.TID = C2.SID and C1.SID > C1.TID
AND C.SID = C1.SID AND C.TID = C1.TID
);