我想在mysql中实现如下要求的sql,
表a如下:
id settle_id status pay_amt
01 001 S 500
02 001 S 100
03 001 N 200
04 002 S 900
05 002 S 200
我想查询出相同settle_id下status全部为S的settle_id,如上表应该查出的记录是:002.
请问mysql中应该怎么实现。
------解决方案--------------------
------解决方案--------------------
- SQL code
if object_id('tb')is not NULLdrop table tbgocreate table tb(id varchar(100),settle_id varchar(100),status varchar(100),pay_amt varchar(100))insert into tbselect '01','001','S','500' union select '02','001','S','100' unionselect '03','001','N','200' unionselect '04','002','S','900' unionselect '05','002','S','200'--select * from tbSELECT * FROM tb a WHERE status='S'AND NOT EXISTS(SELECT 1 FROM tb WHERE settle_id=a.settle_id AND status<>a.status) /*id settle_id status pay_amt04 002 S 90005 002 S 200*/