zoukankan      html  css  js  c++  java
  • sql表连接 —— join

    一、内连接 —— INNER JOIN

    内连接是最常见的一种连接,只连接匹配的行。

    表1:

    表2:

    执行查询:

    select StudentId as 学生编号,StudentName as 姓名,Gender as 性别,Likes as 爱好,ClassName as 所在班级 from Students a
    inner join Class b
    on a.ClassID = b.ClassId

    效果:

     二、外连接 —— LEFT JOIN

    返回左表的全部行和右表满足ON条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用NULL代替。

    还是上面的俩个表,查询语句更改为:

    select StudentId as 学生编号,StudentName as 姓名,Gender as 性别,Likes as 爱好,ClassName as 所在班级 from Students a
    left join Class b
    on a.ClassID = b.ClassId

    效果:

     三、外连接 —— RIGHT JOIN

     返回右表的全部行和左表满足ON条件的行,如果右表的行在左表中没有匹配,那么这一行左表中对应数据用NULL代替。

     还是上面的俩个表,查询语句更改为:

    select StudentId as 学生编号,StudentName as 姓名,Gender as 性别,Likes as 爱好,ClassName as 所在班级 from Students a
    right join Class b
    on a.ClassID = b.ClassId

    效果:

    四、外连接 —— FULL OUTER JOIN

    会从左表 和右表 那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替

    还是上面的俩个表,查询语句更改为:

    select StudentId as 学生编号,StudentName as 姓名,Gender as 性别,Likes as 爱好,ClassName as 所在班级 from Students a
    full outer join Class b
    on a.ClassID = b.ClassId

    效果:

  • 相关阅读:
    数列分段
    2020-01-21 数组 最大子序和
    2020-01-21 数组
    补 2020-01-20 数组 删除排序数组中的重复项
    补2020-01-19 数组 两数之和
    2020-01-18 刷题 螺旋矩阵 II
    2020-01-16 刷题 长度最小的子数组
    2020-01-15 刷题 移除元素
    2020-01-14 QT学习记录
    2020-01-14 数组刷题-1
  • 原文地址:https://www.cnblogs.com/xulinjun/p/11956417.html
Copyright © 2011-2022 走看看