日期:2014-05-17  浏览次数:20562 次

关于分组判断值是否一致的sql语句编写
我想在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
ELECT * FROM [tb] AS t WHERE [status]='S'
AND NOT EXISTS(SELECT 1 FROM tb WHERE [settle_id]=t.[settle_id] AND [status]!=t.[status])

------解决方案--------------------
SQL code
if object_id('tb')is not NULL
drop table tb
go
create table tb(id varchar(100),settle_id varchar(100),status varchar(100),pay_amt varchar(100))
insert into tb
select '01','001','S','500' union 
select '02','001','S','100' union
select '03','001','N','200' union
select '04','002','S','900' union
select '05','002','S','200'

--select * from tb
SELECT * 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_amt
04    002              S          900
05    002              S          200
*/