外连接查询

 外连接查询

Ø  普通连接操作只输出满足连接条件的元组

Ø  外连接操作以指定表为连接主体,将主体表中不满足连接条件的元组一并输出

a)  左连接

左连接是指将左表中的所有数据分别与右表中的每条数据进行连接组合,返回的结果除内连接的数据外,还包括左表中不符合条件的数据,并在右表的相应位置列中添加NULL值。

基本语法:

select table1.column1, table1.column1..., table2.column1,table2.column2... from table1 left [outer] join table2

on table1.column1= table2.column2 [and | or other condition...]

例:course表与sc表左连接

select course.*,sc.* from course left joinsc on course.Cno = sc.Cno;

结果显示了34条数据,除了33条是学生选的课程,还有一条是没有任何学生选的课“数据库”。

可以查看一下sc表中是否有Cno=1的数据

select sc.* from sc where sc.Cno = 1;

可以看出sc中确实没有Cno=1的数据

我们在用内连接方式查看一下结果

select course.*, sc.* from course, sc where course.Cno= sc.Cno;

可以看出,查询结果一共33条数据,也就是学生选的课程记录数目,内连接查询并没有把“数据库”这门课所有学生都没有选的课展示出来。

b)  右连接

右连接是指将右表中的所有数据分别与左表中的每条数据进行连接组合,返回的结果除内连接的数据外,还包括右表中不符合条件的数据,并在左表的相应位置列中添加NULL值。

基本语法:

select table1.column1, table1.column1..., table2.column1,table2.column2... from table1 right [outer] join table2

on table1.column1= table2.column2 [and | or othercondition...]

例:sc表与course表右连接

select course.*, sc.* from sc right outer join courseon course.Cno = sc.Cno;

可以看出未被学生选修的课“数据库”也被显示出来了。


c)   全连接

全连接是指将左表中的所有数据分别与右表中的每条数据进行连接组合,返回的结果除内连接的数据外,还包括左表中不符合条件的数据和右表中不符合条件的数据,并在左表的相应位置列和右表的相应位置列中添加NULL值。

基本语法:

select table1.column1, table1.column1..., table2.column1,table2.column2... from table1 full [outer] join table2

on table1.column1=table2.column2 [and | or other condition...]

注意:mysql不支持全连接


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值