zoukankan      html  css  js  c++  java
  • oracle 内外连接,左连接,右连接 区别

    首先讲解一下 on 与where后面接的条件的区别

    on和where条件的区别如下:
    1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。
    2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。(1,1那条数据就是left join的原则 必须返回左边表的记录,而应该显示的b表的数据就被过滤掉了)

    内外连接是主要区别就是主表的数据是否有过滤操作。例如有两张表(a/b) 结构分别如下图:

    但是通过内外连接查出来的数据明显是不同的,下面就举例说明(有点特殊的例子,在on后面加的条件,因为如果在where后加条件的话,就不在存在内外连接的意义了):

    on、where、having的区别

    on、where、having这三个都可以加条件的子句中,on是最先执行,where次之,having最后。有时候如果这先后顺序不影响中间结果的话,那最终结果是相同的。但因为on是先把不符合条件的记录过滤后才进行统计,它就可以减少中间运算要处理的数据,按理说应该速度是最快的。


    作者:wangqc
    出处:http://www.cnblogs.com/wangqc/
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
    该文章也同时发布在我的独立博客中-wangqc

  • 相关阅读:
    C# 动态加载控件 (转)
    SQL 周月时间段
    js调用xml数据显示div层上下滚动的公告
    使用半透明的DIV实现禁用页面功能(转)
    学习jQuery第一天"Hello!How are you!"
    HTML生成类
    从无限畅想转来的
    SQL递归查询子类型
    js 图片缩显
    2020年统计用区划代码和城乡划分代码:安徽省乡镇编码
  • 原文地址:https://www.cnblogs.com/wangqc/p/oracle_neiwailianjie.html
Copyright © 2011-2022 走看看