zoukankan      html  css  js  c++  java
  • mysql left join 出现的结果会重复

    left join 基本用法

    MySQL 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表的记录数。

    所以解决办法 都是从一个出发点出发,使A表与B表所显示的记录数为 1:1对应关系。

    解决方法

    1、select DISTINCT(id) from a left join b on a.id=b.aid   DISTINCT查询结果是  第一个表唯一的数据   重复的结果没显示出来

    2、select * from a left join(select id from b group by id) as b on a.id=b.aid  拿出b表的一条数据关联  使A表与B表所显示的记录数为 1:1对应关系。

    3、select * from a left join (select  max(id)  from table  group by id) as b on a.id=b.aid  拿出b表的最后一条数据关联

  • 相关阅读:
    2014华为上机题(转)
    c语言scanf详解
    Linux环境下Android JNI程序的编译
    C++中cin、cin.get()、cin.getline()、getline()、gets()等函数的用法
    容器化交付流程设计
    阿里云云计算相关术语概念
    k8s的部署策略
    pod控制器介绍
    Statefulset详细解析
    k8s持久化状态存储原理
  • 原文地址:https://www.cnblogs.com/ampl/p/9081746.html
Copyright © 2011-2022 走看看