zoukankan      html  css  js  c++  java
  • sql 表的连接 inner join、full join、left join、right join、natural join

    一、内连接-inner jion :

    SELECT * FROM table1 INNER JOIN table2 ON table1.field1 compopr table2.field2

    INNER JOIN 运算可分为以下几个部分:

    部分   说明  

    table1, table2   记录被组合的表的名称。  

    field1, field2   被联接的字段的名称。若它们不是由数字构成的,则这些字段必须为相同的数据类型并包含同类数据,但它们无须具有相同的名称。  

    select s.name,m.mark from student s,mark m where s.id=m.studentid
    select s.name,m.mark from student s inner join mark m on s.id=m.studentid

    二、左连接-left join:

     连接通常可以在select语句的from子句或where子句中建立,其语法格式为:

            from join_table join_type join_table

            [on (join_condition)]

            其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一个表操作的连接称为自连接, join_type 为连接类型,可以是left join 或者outer join 或者inner join 。

            on (join_condition)用来指连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。

    左连接是把左边的表的元组全部选出来:

    select s.name,m.mark from student s left join mark m on s.id=m.studentid

    三、右连接-right join:

    连接通常可以在select语句的from子句或where子句中建立,其语法格式为:

     from join_table join_type join_table

            [on (join_condition)]

    其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作。对同一个表操作的连接称为自连接

    on (join_condition)用来指连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。

    右连接就是把右边表的数据全部取出,不管左边的表是否有匹配的数据:

    select s.name,m.mark from student s right join mark m on s.id=m.studentid

    四、全连接-full join:

    使用格式如上面的用法  在上面已经说明

    把左右两个表的数据都取出来,不管是否匹配:

    select s.name,m.mark from student s full join mark m on s.id=m.studentid

     五、自然连接-NATURAL JOIN

    在俩个表中间只有一个共同项   同时也是我们需要匹配的项时  

    我们可以直接使用自然链接

    FROM dept_emp d NATURAL JOIN employees e

    不需要自己添加匹配条件

  • 相关阅读:
    LeetCode
    lintcode--剑指offer
    lintcode--剑指offer---41--50道
    LeetCode中的bug!!!!!!
    常用知识点
    lintcode--剑指offer---31--40道
    LeetCode--链表
    Java设计实践课练习题
    lintcode--剑指offer---21--30道
    Java设计实践课的LeetCode题目
  • 原文地址:https://www.cnblogs.com/52why/p/7634321.html
Copyright © 2011-2022 走看看