mysql离开加入和联盟?

时间:2012-01-02 18:28:10

标签: php mysql join

我有这个左连接查询,以显示所有职位列表给位于特定主管的签名组中的员工,它运作良好

SELECT * 
FROM jobs j 
LEFT JOIN groups g ON g.group_number = j.relevant_group 
WHERE j.relevant_group = 0 
OR (g.supervisor_id = j.job_lister_id AND g.employee_id = '$myVar') 

但是,现在我需要添加一个选择,以便发布主管也可以看到它,我设置$ myVar来保存查看器的会话ID。我试过这个

SELECT * 
FROM jobs j 
LEFT JOIN groups g ON g.group_number = j.relevant_group 
WHERE j.relevant_group = 0 
OR (g.supervisor_id = j.job_lister_id AND g.employee_id = '$myVar')
OR (j.job_lister_id = '$myVar')

但是当主管登录时,他看到列表多次发布(重复数量总是等于组中的人数) 我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

您确实需要groups中的任何字段才能显示在结果集中吗?因为听起来您只是使用groups来识别要返回的jobs条记录?如果是这种情况,那么您应该省略JOIN,并使用子查询。例如,您可以写:

SELECT * 
  FROM jobs j
 WHERE j.job_lister_id = '$myVar'
    OR j.relevant_group = 0
    OR EXISTS
        ( SELECT 1
            FROM groups g
           WHERE g.group_number = j.relevant_group
             AND g.supervisor_id = j.job_lister_id
             AND g.employee_id = '$myVar'
        )
;