>  기사  >  데이터 베이스  >  取满足所有条件的记录

取满足所有条件的记录

WBOY
WBOY원래의
2016-06-07 15:22:431034검색

Table_A表是用户表,Table_B是条件表,每个用户对应多个条件,并且用户对应条件的状态有可能是true或者false,现在需要找出在Table_B中所有条件都是true的用户。 Table_A表的数据 Table_B表的数据 通过分析A表和B表的数据可以得出,只有用户王二满足所有条件

Table_A表是用户表,Table_B是条件表,每个用户对应多个条件,并且用户对应条件的状态有可能是true或者false,现在需要找出在Table_B中所有条件都是true的用户。

Table_A表的数据

Table_B表的数据

通过分析A表和B表的数据可以得出,只有用户“王二”满足所有条件,期望的结果就是 

实现SQL语句

select a.* from
(
  SELECT [AId],sum(case when [State]='true' then 0 else 1 end) as total
  FROM [Table_B]
  group by [AId]
) b inner join [Table_A] a on b.AId=a.Id 
where total =0
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.