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是职位表,我想统计出每个分类下职位的数量。
但是结果有点问题,如果某个分类在职位表的分类字段里不存在,也就是说这个分类下没人添加过职位,那么查询结果中这个分类也不会显示。
但是按理说如果左联的话,右表就算没有对应的数据,左表的字段也应该显示的啊
漂亮男人2017-06-05 11:10:00
我也遇到过这种情况,是你的where条件筛选掉了。解决办法,把写在where里的条件追加在on里面!
where是对连表后的结果集进行筛选,但是on里面的条件如果为假,左表的数据会返回,右表全为空