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

    效果:

  • 相关阅读:
    Tomcat建立多个应用(Web Server),多个主机,多个站点的方法
    Spring 注解bean默认名称规则
    spring+springMVC,声明式事务失效,原因以及解决办法
    Spring事务失效的原因
    MySQL 对于千万级的大表要怎么优化?
    前端开发利器: Bootstrap + AngularJS
    scrapy爬取段子
    scrapy安装
    xpath和CSS选择器
    pycharm远程登录mysql
  • 原文地址:https://www.cnblogs.com/xulinjun/p/11956417.html
Copyright © 2011-2022 走看看