zoukankan      html  css  js  c++  java
  • 小示例分清表接关系

    -- 一个小示例分清 左右连接 与 外连接 关系

    -- 表顺序 t1 t2(注意表的前后排列顺序)

    -- 左连接,(+)号在右边,也就是 t2 这边,(+)号边交集

    -- 右连接,(+)号在左边,也就是 t1 这边,(+)号边交集

    image
    select * from(
    select 1 a, 2 b from dual
    union all
    select 2 a, 3 b from dual
    union all
    select 3 a, 4 b from dual
    ) t1
    -- left join 就是以左边集(t1)为全集,左边的全集 t1 全取出来,而右边集取 t1 t2 交集
    left join (
    select 1 a, 2 b from dual
    union all
    select 1 a, 7 b from dual
    union all
    select 2 a, 7 b from dual
    union all
    select 4 a, 7 b from dual
    ) t2
    on t1.a = t2.a

    image

    select * from(
    select 1 a, 2 b from dual
    union all
    select 2 a, 3 b from dual
    union all
    select 3 a, 4 b from dual
    ) t1,
    (
    select 1 a, 2 b from dual
    union all
    select 1 a, 7 b from dual
    union all
    select 2 a, 7 b from dual
    union all
    select 4 a, 7 b from dual
    ) t2
    where 1=1
    and t1.a = t2.a(+) -- 找出 (t1 t2 交集)+ (t1 在 t2 的差集)

    image

    select * from(
    select 1 a, 2 b from dual
    union all
    select 2 a, 3 b from dual
    union all
    select 3 a, 4 b from dual
    ) t1
    -- right join 就是以右边集(t2)为全集,左边集取 t1 t2 交集,而右边全集 t1 全取出来
    right join (
    select 1 a, 2 b from dual
    union all
    select 1 a, 7 b from dual
    union all
    select 2 a, 7 b from dual
    union all
    select 4 a, 7 b from dual
    ) t2
    on t1.a = t2.a

    image

    select * from(
    select 1 a, 2 b from dual
    union all
    select 2 a, 3 b from dual
    union all
    select 3 a, 4 b from dual
    ) t1,
    (
    select 1 a, 2 b from dual
    union all
    select 1 a, 7 b from dual
    union all
    select 2 a, 7 b from dual
    union all
    select 4 a, 7 b from dual
    ) t2
    where 1=1
    and t1.a(+) = t2.a  -- 找出 (t1 t2 交集)+ (t2 在 t1 的差集)

    image

    select * from(
    select 1 a, 2 b from dual
    union all
    select 2 a, 3 b from dual
    union all
    select 3 a, 4 b from dual
    ) t1
    -- full join = left join + rigth join 就是取 t1 t2 交集,同时也取 t1 t2 各自差集
    full join (
    select 1 a, 2 b from dual
    union all
    select 2 a, 7 b from dual
    union all
    select 4 a, 7 b from dual
    ) t2
    on t1.a = t2.a

  • 相关阅读:
    计算机网络基础1
    jmeter 之系统参数根据条件修改
    jmeter 之变量传递
    ant 执行jmeter脚本
    ant安装报错:ANT_HOME is set incorrectly or ant could not be located. Please set ANT_HOME.
    数据类型的转换
    你真的了解JavaScript的数据类型吗?
    js的一些常识
    数组扁平化
    vue.config.js
  • 原文地址:https://www.cnblogs.com/quanweiru/p/2740697.html
Copyright © 2011-2022 走看看