如果相同user_id的值存在,请选择记录

时间:2013-03-11 13:39:00

标签: mysql sql select relational-division

我需要从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的记录,即使用户没有这两个值。我怎么办?

1 个答案:

答案 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