我需要从mysql数据库中获取记录;在此表中,有一个与用户关联的操作列表。我需要让所有具有列操作= 3和列操作= 5的用户;例如,如果用户nr。 4有一个action = 3的记录,另一个有action = 5我得到它;如果用户只有一个action = 3或action = 5的记录,我一定不能得到它。如果我写这个查询
SELECT *
FROM user_action
WHERE action = 3 AND action = 5
我总是得到0条记录。如果我写OR而不是AND我得到所有有action = 3或action = 5的记录,即使用户没有这两个值。我怎么办?
答案 0 :(得分:4)
此问题有点称为Relational Division
SELECT userID
FROM user_action
WHERE action IN (3,5)
GROUP BY userID
HAVING COUNT(DISTINCT action) = 2
如果action
对于每个userID
都是唯一的,您可以直接COUNT()
不带DISTINCT
的记录
SELECT userID
FROM user_action
WHERE action IN (3,5)
GROUP BY userID
HAVING COUNT(*) = 2
最后,如果你想获得用户的全部细节,你需要自己加入,
SELECT a.*
FROM user_action a
INNER JOIN
(
SELECT userID
FROM user_action
WHERE action IN (3,5)
GROUP BY userID
HAVING COUNT(*) = 2
) b ON a.userID = b.userID