php - mysql的左联查询,右表某字段为空的时候,为什么左表对应的字段也查不出来?
高洛峰
高洛峰 2017-06-05 11:08:00
0
2
391
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是职位表,我想统计出每个分类下职位的数量。
但是结果有点问题,如果某个分类在职位表的分类字段里不存在,也就是说这个分类下没人添加过职位,那么查询结果中这个分类也不会显示。
但是按理说如果左联的话,右表就算没有对应的数据,左表的字段也应该显示的啊

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(2)
刘奇

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

漂亮男人

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!