left join on 和where条件的放置
select * from
td
left join (
select case_id as sup_case_id , count(*) supervise_number from
td_kcdc_case_sup_info
group by case_id
) sup
on
sup.sup_case_id = td.case_id
where 1=1 /*不能去掉, 否则认为and 后的条件为 联合查询时的条件, 不能起过滤作用,由于left join因此td表中记录将全部查出来*/
and td.con = 'xxxx'
总结:
1. 对于left join,不管on后面跟什么条件,左表的数据全部查出来,因此要想过滤需把条件放到where后面
2. 对于inner join,满足on后面的条件表的数据才能查出,可以起到过滤作用。也可以把条件放到where后面。
转自:http://blog.csdn.net/muxiaoshan/article/details/7617533
posted on 2017-02-16 13:59 struggle_beiJing 阅读(203) 评论(0) 编辑 收藏 举报