两个表:员工和工资
即使使用左连接工资表为空,我也可以从员工那里获取所有记录,但是当我在工资表上使用 where 时,它并不能获取所有员工。
如何获取所有员工记录??????
SELECT `s`.`basic_salary`,`e`.`name`
FROM (`employees` as e)
LEFT JOIN `salaries` as s ON `s`.`employee_id`=`e`.`employee_id`
WHERE `s`.`session_id` = '19' AND `s`.`month_id` = '7'
GROUP BY `e`.`employee_id`
最佳答案
第二个表的条件需要进入on
子句:
SELECT s.`basic_salary`, e.`name`
FROM `employees` e LEFT JOIN
`salaries` s
ON `s`.`employee_id`=`e`.`employee_id` AND
`s`.`session_id` = '19' AND `s`.`month_id` = '7'
GROUP BY e.`employee_id`
否则,您会将外连接转换为内连接。
关于php - 获取一张表的所有数据,而另一张表为空且也应用where子句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45554050/