zoukankan      html  css  js  c++  java
  • mysql join on and

    2018-6-4 10:28:50 星期一

    开发中一直在用 left join, 心中只有一丝丝的了解, 还都是学校里学的, 今天看了几遍文章这里记录一下

    sql的left join 、right join 、inner join之间的区别

      left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 
      right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
      inner join(等值连接) 只返回两个表中联结字段相等的记录

    参考

    join 检索过程

    先匹配ON中的条件, 然后再筛选where中的条件

    "

    ON 条件(“A LEFT JOIN B ON 条件表达式”中的ON)用来决定如何从 B 表中检索数据行。

    如果 B 表中没有任何一行数据匹配 ON 的条件,将会额外生成一行所有列为 NULL 的数据,在匹配阶段 WHERE 子句的条件都不会被使用。

    仅在匹配阶段完成以后,WHERE 子句条件才会被使用。它将从匹配阶段产生的数据中检索过滤。

    "

    参考

    注意点:

    1. 要保证返回结果正确的前提下再进行效率分析, 比如 left join 可能会产生多余的包含NULL的行, 要先决定这样的结果是否正确

    2. inner join 要返回两边都符合on条件的记录, 所以 on中的匹配条件要作用于两个表, 而 left join 中的on只作用于右表

    join on and

    有时候会看到这样的写法:

    1. A LEFT JOIN B ON A.id=B.id  AND b.status=0

    2. A INNER JOIN B ON A.id=B.id  AND b.status=0

    注意: 只有在用 inner join 的时候 AND b.status=0 才会起到筛选作用, 也就是在联结的时候, 只跟B表的status=0的字段进行联结, (如果数据量比较大或是连接的表比较多, 这个写法还是很省时间的)

    而 1中left join 后边的 and 语句并不会起到筛选的作用

  • 相关阅读:
    RHEL7使用ssm命令管理LVM
    LVM命令摘要
    Linux用户磁盘配额
    Linux磁盘分区实战案例
    通过yum升级CentOS/RHEL最小化安装
    RHEL7下PXE+FTP+Kickstart无人值守安装操作系统
    配置VSFTP服务器
    RHEL7下PXE+NFS+Kickstart无人值守安装操作系统
    RHEL7下PXE+Apache+Kickstart无人值守安装操作系统
    html5实现图片自适应手机屏幕页面的css
  • 原文地址:https://www.cnblogs.com/iLoveMyD/p/9132161.html
Copyright © 2011-2022 走看看