首页  >  问答  >  正文

php - mysql的左联查询,右表某字段为空的时候,为什么左表对应的字段也查不出来?

SELECT category.c_id,category.c_name,jobs.amount FROM qs_category as category 
LEFT JOIN qs_jobs as jobs ON category.c_id=jobs.trade 
WHERE jobs.addtime >= 1483200000 AND jobs.addtime <= 1498838400 

这是查询语句,左表category是分类表,右表jobs是职位表,我想统计出每个分类下职位的数量。
但是结果有点问题,如果某个分类在职位表的分类字段里不存在,也就是说这个分类下没人添加过职位,那么查询结果中这个分类也不会显示。
但是按理说如果左联的话,右表就算没有对应的数据,左表的字段也应该显示的啊

高洛峰高洛峰2715 天前437

全部回复(2)我来回复

  • 怪我咯

    怪我咯2017-06-05 11:10:00

    你where条件写的右边的表,当然查不出来拉,右表为空的时候条件字段也为空,被你where筛选掉了。

    回复
    0
  • 漂亮男人

    漂亮男人2017-06-05 11:10:00

    我也遇到过这种情况,是你的where条件筛选掉了。解决办法,把写在where里的条件追加在on里面!
    where是对连表后的结果集进行筛选,但是on里面的条件如果为假,左表的数据会返回,右表全为空

    回复
    0
  • 取消回复