使用语句的先后顺序并不是优先级的排序:

连接分为:内连接和外连接,外连接分为左外连接,右外连接,全连接

概念上解释,表之间联合后数据如何整合。

返回的数据条数,可以通过集合求算。假如A集合有10条数据,B集合有8条数据,交集的有3条数据。

左外连接:左表的数据全部保留,右表中如果没有满足条件的用null对应。返回数据条数假如A是左表,B是右表,那么返回10条。

内连接:两个表连接条件都存在数据保留,相当于数据集合的交集。返回数据条数假如A是左表,B是右表,那么返回3条。

右外连接:右表数据全部保留,左表中如果没有满足条件的用null对应。返回数据条数假如A是左表,B是右表,那么返回8条。

全连接:左表右表数据全部保留。返回数据条数假如A是左表,B是右表,那么返回13条。

语句:

内连接: table A inner join table B on(条件)/ table A inner join table B using(连接字段名称在两个表中相同)。

左外连接:table A left join table B on(条件)/table A left join table B on(连接字段名称在两个表中相同)。

右外连接:table A right join table B on(条件)/table A right join table B on(连接字段名称在两个表中相同)。

全连接(全外连接):table A full join table B on(条件)/table A full join table B on(连接字段名称在两个表中相同)。

测试实例:

测试表:

create table tbl_course(
course_id bigint not null primary key,
course_name varchar(12) not null
); create table tbl_student(
stu_id bigint not null,
stu_name varchar(12),
constraint pk_tbl_student_stu_id primary key(stu_id)
); create table tbl_student_course(
stu_id bigint not null,
course_id bigint not null,
constraint pk_tbl_student_course_stu_id_course_id primary key(stu_id,course_id),
constraint fk_tbl_student_course_stu_id foreign key(stu_id) references tbl_student(stu_id) ,
constraint fk_tbl_student_course_course_id foreign key(course_id) references tbl_course(course_id)
);
insert into tbl_course values(1,‘高等数学‘),(2,‘大学英语‘),(3,‘大学物理‘),(4,‘电影欣赏‘);
insert into tbl_student values(1,‘张三‘),(2,‘李四‘),(3,‘王五‘),(4,‘麻子‘);
insert into tbl_student_course values (1,2),(1,4),(2,4),(3,4);

二.内连接


INNER JOIN,其中INNER可以省略。


语法:


A INNER JOIN B ON (A.a = B.b)


如果ON条件中两张表的字段名称相同,还可以简单一点


A INNER JOIN B USING(a = b)


内连接的结果如下图中红色部分




示例:查询选课情况


test=# select * from tbl_student_course join tbl_student using(stu_id) join tbl_course using(course_id);
course_id | stu_id | stu_name | course_name
-----------+--------+----------+-------------
2 | 1 | 张三 | 大学英语
4 | 1 | 张三 | 电影欣赏
4 | 2 | 李四 | 电影欣赏
4 | 3 | 王五 | 电影欣赏
(4 rows)


三.左外连接


左外连接其实是一个内连接然后加上左表独有的数据行,结果集中右表的字段自动补充NULL。


LEFT OUTTER JOIN ,其中OUTTER可以省略。


语法:


A LEFT JOIN B ON (A.a=B.b)


A LEFT JOIN B USING(a)


左外连接的结果如下图红色部分




示例:查询所有学生的选课信息,包括没选课的学生


test=# select * from tbl_student left join tbl_student_course using(stu_id) left join tbl_course using(course_id);
course_id | stu_id | stu_name | course_name
-----------+--------+----------+-------------
2 | 1 | 张三 | 大学英语
4 | 1 | 张三 | 电影欣赏
4 | 2 | 李四 | 电影欣赏
4 | 3 | 王五 | 电影欣赏
NULL | 4 | 麻子 | NULL
(5 rows)


四.右外连接


右外连接其实是一个内连接然后加上右表独有的数据行,结果集中左表的字段自动补充NULL。


RIGHT OUTTER JOIN ,其中OUTTER可以省略。


语法:


A RIGHT JOIN B ON (A.a=B.b)


A RIGHT JOIN B USING(a)


右外连接的结果如下图红色部分



示例:查询所有课程被选情况


test=# select * from tbl_student right join tbl_student_course using(stu_id) right join tbl_course using(course_id);
course_id | stu_id | stu_name | course_name
-----------+--------+----------+-------------
2 | 1 | 张三 | 大学英语
4 | 1 | 张三 | 电影欣赏
4 | 2 | 李四 | 电影欣赏
4 | 3 | 王五 | 电影欣赏
3 | NULL | NULL | 大学物理
1 | NULL | NULL | 高等数学
(6 rows)


五.全外连接


全外连接其实是一个内连接然后加上左表和右表独有的数据行,左表独有的数据行右表的字段补充NULL,右表独有的数据行左表字段补充NULL。


FULL OUTTER JOIN,其中OUTTER可以省略。


语法:


A FULL OUTTER JOIN B ON (A.a = B.b)


A FULL OUTTER JOIN B USING(a)


全外连接的结果如下图红色部分




示例:查询所有学生和课程的选课信息


test=# select * from tbl_student full join tbl_student_course using(stu_id) full join tbl_course using(course_id);
course_id | stu_id | stu_name | course_name
-----------+--------+----------+-------------
2 | 1 | 张三 | 大学英语
4 | 1 | 张三 | 电影欣赏
4 | 2 | 李四 | 电影欣赏
4 | 3 | 王五 | 电影欣赏
NULL | 4 | 麻子 | NULL
3 | NULL | NULL | 大学物理
1 | NULL | NULL | 高等数学
(7 rows)


查询只在左表存在的数据




示例:查询没有选课的学生


test=# select * from tbl_student left join tbl_student_course using(stu_id) where tbl_student_course.stu_id is null;
stu_id | stu_name | course_id
--------+----------+-----------
4 | 麻子 | NULL
(1 row)


NOT IN存在很大的性能瓶颈,除NOT EXISTS外,也可以使用这种查询方式作为替代方案。


查询只在右表中存在的数据




示例:查询没有被选的课程


test=# select * from tbl_student_course right join tbl_course using(course_id) where tbl_student_course.course_id is null;
course_id | stu_id | course_name
-----------+--------+-------------
1 | NULL | 高等数学
3 | NULL | 大学物理
(2 rows)



查询只在左表或只在右表存在的数据




示例:查询没有选课的学生和没有被选的课程


test=# select * from tbl_student full join tbl_student_course using(stu_id) full join tbl_course using(course_id)  where tbl_student.stu_id is null or tbl_course.course_id is null;
course_id | stu_id | stu_name | course_name
-----------+--------+----------+-------------
NULL | 4 | 麻子 | NULL
3 | NULL | NULL | 大学物理
1 | NULL | NULL | 高等数学
(3 rows)


所有的JOIN查询,只要理解了下面的图,一切就OK了!



postgresql 多表联查的更多相关文章

  1. mybatis.net 多表联查

    mybatis.net针对多表联查,其实不用讲联查出的所有的列全部做一个新的resultMap,我们完全可以通过集成关系来实现,真是上一次说的懒加载,在一定程度上可以提高其性能,但这并不是说懒加载性能 ...

  2. CDH中,执行HIVE脚本表联查权限问题。。

    文章来自http://www.cnblogs.com/hark0623/p/4174641.html 转发请注明 有时候执行表联查的时候总会出现没有权限写文件的情况. 这个时候使用sudo -H hi ...

  3. Postgresql两表联结更新

    Postgresql两表联合更新近日使用Postgresql感到有点不好用,一个联合更新非要这样写语法才对:update d_routetripset name=b.name ,    descrip ...

  4. MVC +EF+linq 多表联查

    关于linq的多表联查效果的实现: 后台多表查询  内连接: SELECT [Extent2].[partID] AS [partID], [Extent1].[userName] AS [userN ...

  5. 使用mybatis多表联查的时候结果异常及springmvc的理解

    今天使用mybatis多表联查的时候,在dos窗口查询时可以出结果集,但是使用mybatis查询的时候最后返回的结果只有最后一个结果 然后研究了半天没弄出来,后来无意中发现添加了最外层从表的ID字段后 ...

  6. asp.net mvc 三层加EF两表联查

    首先打开vs软件新建项目创建web中的mvc项目再右击解决方案创建类库项目分别创建DAL层和BLL层再把DAL层和BLL层的类重命名在mvc项目中的Models文件夹创建model类在DAL创建ADO ...

  7. SQLServer多表联查,多表分页查询

    多表联查: select p.*,s.Sheng , i.Shifrom  [dbo].[ProductRecordInfo]   --表名 p left join [ShengInfo] s on ...

  8. [工作日志] 2018-11-30 重要: 1. 多条件+ 分页 + 多表联查 2. idea拉新分支

    多条件+ 分页 + 多表联查 多条件查询 1.pom依赖 <dependency> <groupId>commons-dbutils</groupId> <a ...

  9. .NET MVC+ EF+调用存储过程 多表联查以及VIEW列表显示

    直接上干活,至于网上的一大堆处理方式不予评论,做好自己的就是最好的,供大家不走弯路 1.view页面 <link href="~/Content/bootstrap.css" ...

随机推荐

  1. HDFS中NameNode启动过程

    移动到hadoop文件目录下 NameNode启动命令:sbin/hadoop-daemon.sh start namenode DataNode启动命令:sbin/hadoop-daemon.sh ...

  2. java复习(9)---数据库JDBC

    java写工程当然需要连接数据库.JDBC技术是连接数据库和应用程序的纽带,本节主要说明如何连接数据库. java中提供sql类. package re09; import java.sql.*; p ...

  3. 战斗逻辑 - demo

    创建战斗依赖的数据结构 /** * 角色属性 */ var a_data = { _id: 101, attr: { // 角色战斗属性 }, skill: [],// 技能数组 isAtk: fal ...

  4. js解决苹果移动端300ms延迟的问题

    做移动端页面开发的可能会了解到,ios系统click事件会有卡顿的现象,这个问题的根源是苹果本身自带的safari有双击放大页面的功能,再次双击会返回到原始尺寸,所以在第一次点击的系统会延迟300ms ...

  5. Hive 的简单使用及调优参考文档

    Hive 的简单使用及调优参考文档   HIVE的使用 命令行界面 使用一下命令查看hive的命令行页面, hive --help --service cli 简化命令为hive –h 会输出下面的这 ...

  6. jquery虎牙TV3D轮播特效

    css部分: *{ margin: 0px; padding: 0px; } body{ margin: 0px; padding: 0px; text-align: center; } #banne ...

  7. Vmware Vsphere WebService之vijava 开发一-vcenter连接、及集群信息获取

    开始是通过java代码调用vsphere提供的原始接口,从而控制vcenter的操作.当第一个版本做完之后发现代码执行的速度特别慢,后来在网上看到有人用vijava(对vsphere原始接口封装)编程 ...

  8. iOS开发 - Swift实现清除缓存功能

    前言: 开发移动应用时,请求网络资源是再常见不过的功能.如果每次都去请求,不但浪费时间,用户体验也会变差,所以移动应用都会做离线缓存处理,其中已图片缓存最为常见. 但是时间长了,离线缓存会占用大量的手 ...

  9. ReactiveCocoa学习总结(2)

    信号(signal)- RACSignal类 1. 一般表示将来有数据传递,只要有数据改变,信号内部接收到数据,就会马上发出数据. 2. 事件类型: next:发送数据到下一个管道 error:发送数 ...

  10. 属于自己的MES(一)概念

    什么叫MES(生产制造执行系统)? 从几个方面来简单说下: 1.定位 没有MES前的工厂生产模式,公司MRP系统与生产现场之间透过人为方式沟通,使生产现场如同黑箱作业,无法掌握实时正确信息. MES的 ...