我有这个 mysql 表(如下图)。我想选择按 id 分组的 id
其中:
datakey = label 和 datavalue = is_member
并且同时 where:
datakey = since 和 datavalue = 20110204
所以最终结果应该只是105。
我怎样才能做到这一点?
我有这个 mysql 表(如下图)。我想选择按 id 分组的 id
其中:
datakey = label 和 datavalue = is_member
并且同时 where:
datakey = since 和 datavalue = 20110204
所以最终结果应该只是105。
我怎样才能做到这一点?
应该可以在不加入的情况下实现这一点。 http://www.sqlfiddle.com/#!2/ca8d6/1
SELECT t.id
FROM table_name t
WHERE (datakey = 'Label' AND datavalue = 'is_member') OR (datakey = 'Since' AND datavalue = '20110204')
GROUP BY t.id
HAVING COUNT(datakey) = 2;
这应该得到你需要的
SELECT
a.id
FROM
some_table AS a
JOIN some_table AS b
ON
b.id = a.id
WHERE
a.datakey = 'Label'
AND
a.datavalue = 'is_member'
AND
b.datakey = 'Since'
AND
b.datavalue = '20110204'
这里的假设是,该字段id
引用相同的数据集。