七叶笔记 » 数据库 » postgreSQL中的内连接和外连接实现操作

postgreSQL中的内连接和外连接实现操作

person表:

一:内连接: 1.inner join

inner join(等值连接) 只返回两个表中联结字段相等的行

sql语句:

也可以写成:

结果如下:

从结果可以看出,表格中显示出了city.id=person.id的记录,它显示出了符合这个条件的记录。

二:外连接: 1.full outer join

full outer join(全外连接)返回参与连接的两个数据集合中的全部数据

sql语句:

也可以写成:

结果如下:

从结果可以看出,全外连接得到了city和person表中的全部数据

2.left outer join

left outer join(左连接) 返回包括左表中的所有记录和右表中连接字段相等的记录

sql语句:

也可以写成:

结果如下:

从结果可以看出,左外连接和全外连接的结果一模一样?

我们在给person中添加一行数据:

在重新执行:

结果如下:

结果如下:

两个结果对照着看,left join显示出了city中的所有记录和person连接字段相等的记录

3.right outer join

right outer join(右连接) 返回包括右表中的所有记录和左表中连接字段相等的记录

sql语句:

也可以写成

结果如下:

从结果可以看出,person中的记录被全部显示出来,而city中的显示的数据是根据连接字段相等的记录

补充:PostgreSQL表连接:内连接,外连接,自连接,交叉连接

搜了搜,基本上都是写内连接、外连接、交叉连接这三种类型,但我发现PostgreSQL还有自连接。不妨一并写来做个记录。

先说概念:

内连接,就是两个表逐行匹配,匹配上的内容都显示,没有匹配的都不显示。

外连接有三种,左外连接,右外连接,全外连接。

左外连接是以左表为基础,左表内容全部显示,右表有匹配到左表的则显示,否则不显示。

右外连接是以右表为基础,右表内容全部显示,左表有匹配到右表的则显示,否则不显示。

全外连接是以两表为基础,显示三部分内容,一部分是内连接的内容,即两表匹配的内容,一部分是左表有而右表无的,一部分是左表无右表有的。

自连接是逐行,用当前这行数据和这个表中其他行进行匹配。

交叉连接最省事,笛卡尔积,左表m行右表n行,则结果是m*n行。

下面展示具体例子来帮助理解。

下面是两个表的内容。

内连接有两种写法: 外连接有三种:左外连接,右外连接,全外连接。 表交叉连接: 表自连接:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持七叶笔记。如有错误或未考虑完全的地方,望不吝赐教。

相关文章