leftjoin左表合并去重技巧
left join 语句格式为: A LEFT JOIN B ON 条件表达式;
left join 是以A表为基础,A表即左表,B表即右表。左表(A)的记录会全部显⽰,⽽右表(B)只会显⽰符合条件表达式的记录,如果在右表(B)中没有符合条件的记录,则记录不⾜的地⽅为NULL。
使⽤left join, A表与B表所显⽰的记录数为 1:1 或 1:0,A表的所有记录都会显⽰,B表只显⽰符合条件的记录。但如果B表符合条件的记录数⼤于1条,就会出现1:n的情况,这样left join后的结果,记录数会多于A表的记录数。
针对上述1:n的情况,转换为1:1的关系,需要对B表进⾏去重处理,使⽤⾮唯⼀标识的字段做关联,⽅法如下:
1.DISTINCT 查询结果是第⼀张表唯⼀的数据,重复的数据不会显⽰出来;
SELECT
DISTINCT(a.id)
FROM
table_a a
LEFT JOIN table_b b ON b.base_id = a.id WHERE
a.discard_status =0多表left join
_id = 123456;
2.GROUP BY 拿出b表的⼀条数据关联使A表与B表所显⽰的记录数为 1:1对应关系;
SELECT
COUNT(0)FROM
table_a a
LEFT JOIN (select base_id from table_b group by base_id) b ON b.base_id = a.id
WHERE
a.discard_status =0
_id =123456;
3.max值进⾏唯⼀关联
SELECT
COUNT(0)
FROM
table_a a
LEFT JOIN (select max(id), t.* from table_b t group by base_id) b ON b.base_id = a.id
WHERE
a.discard_status =0
_id =123456;
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论