博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle 中的join
阅读量:7015 次
发布时间:2019-06-28

本文共 1527 字,大约阅读时间需要 5 分钟。

hot3.png

1、概述

1.1、所有的join连接,都可以加上类似where a.id='1000'的条件,达到同样的效果。

1.2、除了cross join不可以加on外,其它join连接都必须加上on关键字,后都可加where条件。

1.3、虽然都可以加where条件,但是他们只在标准连接的结果集上查找where条件。比如左外连接的结果没有class的三班,所以如果加 where class.id='C003'虽然在表中有,但在左连接结果集中没有,所以查询后,是没有记录的。

2、实例,标准的join连接,(不加where条件的)

2.1、设有表如下:

学生表

班级表,对应学生表中的classid

2.2、自连接:join ,inner join

1 --自连接  :只返回两张表连接列的匹配项。 2 --以下三种查询结果一样。 3 select * from student s inner join class c on s.classid=c.id; 4 select * from student s join class c on s.classid=c.id; 5 select * from student s,class c where s.classid=c.id;

自连接结果:

2.3、笛卡儿乘积:cross join

1 --笛卡儿乘积连接 :即不加任何条件,达到 M*N 的结果集。 2 --以下两种查询结果一样。 3 select * from student s cross join class c; 4 select * from student,class;

笛卡尔结果:

注意:如果cross join加上where s.classid=c.id条件,会产生跟自连接一样的结果:

1 --加上条件,产生跟自连接一样的结果。 2 select * from student s cross join class c where s.classid=c.id;

自连接结果集的cross join连接结果

2.3、左外连接:left join

1 --左连接 :列出左边表全部的,及右边表符合条件的,不符合条件的以空值代替。 2 --在(+)计算时,哪个带(+)哪个需要条件符合的,另一个全部的。即放左即右连接,放右即左连接。 3 --以下结果集相同。 4 select * from student s left join class c on s.classid=c.id; 5 select * from student s,class c where s.classid=c.id(+);

左连接结果:

2.4、右外连接:right join

1 --右外连接 :与左连接一样,列出右边表全部的,及左边表符合条件的,不符合条件 2 --的用 空值  替代。 3 --(+)一样,它的位置与连接相反。 4 select * from student s right join class c on s.classid=c.id; 5 select * from student s,class c where s.classid(+)=c.id;

右连接结果

2.5、全连接:full join

1 --全连接 :产生M+N的结果集,列出两表全部的,不符合条件的,以空值代替。 2 select * from student s full join class c on s.classid=c.id;

全连接结果集

转载于:https://my.oschina.net/yangzhiyuan/blog/209445

你可能感兴趣的文章
Oracle IMP-00010: 不是有效的导出文件,标题验证失败
查看>>
Sql Server 常用系统存储过程大全
查看>>
使用easyUI转换HTML table到datagrid
查看>>
Java读书笔记06 继承
查看>>
HDU 4279 Number 第37届ACM/ICPC天津赛区网络赛1002题 (简单规律题)
查看>>
GNU make manual 翻译(五十一)
查看>>
orm 对象关系映射
查看>>
OAuth 2.0 - dotNetDR_OAuth2微博API访问组件使用教程
查看>>
网络管理与相关应用
查看>>
文件内容查阅(转)
查看>>
.net socket在win2008下的吞吐性能报告
查看>>
[转]深入浅出Java设计模式之备忘录模式
查看>>
抽象类到底是个什么玩意
查看>>
Windows Mobile 消除安装程序时显示“此程序来自未知发行者…“提示的方法
查看>>
正则表达式周二挑战赛 - 第十一周
查看>>
How many people have ipad II(数学)
查看>>
自适应对话框的背景位图&限制大小的对话框
查看>>
分享:centos daemon make and install
查看>>
javascript对话框
查看>>
机器学习各类工具weka、scikit-learn等各项指标的对比
查看>>