ホームページ  >  記事  >  データベース  >  取满足所有条件的记录

取满足所有条件的记录

WBOY
WBOYオリジナル
2016-06-07 15:22:431036ブラウズ

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 までご連絡ください。