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

不需要自己添加匹配条件

 

转载于:https://www.cnblogs.com/52why/p/7634321.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值