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

  • 相关阅读:
    frida枚举当前加载的模块以及模块中方法
    python request请求时候json严格校验怎么去除空格
    firda-so静态注册
    LeetCode 724. 寻找数组的中心索引
    LeetCode 679. 24点游戏
    LeetCode 845. 数组中的最长山脉
    并查集各种情况下的时间复杂度
    LeetCode 547. 省份数量
    LeetCode 5. 最长回文子串
    LeetCode 103. 二叉树的锯齿形层序遍历
  • 原文地址:https://www.cnblogs.com/quanweiru/p/2740697.html
Copyright © 2011-2022 走看看