zoukankan      html  css  js  c++  java
  • left join 左表合并去重技巧

      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.idWHERE
        a.discard_status = 0
        AND a.org_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
        AND a.org_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
        AND a.org_id = 123456;
  • 相关阅读:
    Ado.Net 调用存储过程用法
    C程序设计语言练习题1-22
    C程序设计语言练习题1-21
    C程序设计语言练习题1-20
    C程序设计语言练习题1-19
    C程序设计语言练习题1-18
    C程序设计语言练习题1-17
    C程序设计语言练习题1-16
    C程序设计语言练习题1-15
    C程序设计语言练习题1-14
  • 原文地址:https://www.cnblogs.com/jiahm/p/13628840.html
Copyright © 2011-2022 走看看