PostgreSQL 连接 inner join on

PostgreSQL 连接的问题

一、分类

内连接(INNER JOIN)
    左外连接(LEFT OUTER JOIN)
    右外连接(RIGHT OUTER JOIN)
    全连接(FULL OUTER JOIN)
跨连接(CROSS JOIN)

外连接是内联的延伸,外连接有三种类型。 --- 右外连接、左外连接 、全连接

二、详细介绍各种连接

1、内连接(INNER JOIN)

 

内连接,又称简单连接,最常见的连接类型。这个连接返回满足条件的多个表中的所有行。

 

如下图表示 -

语法:


SELECT table1.columns, table2.columns  
FROM table1  
INNER JOIN table2  
ON table1.common_filed = table2.common_field;

在这里要重新创建一张表

查询内连接的两个表


2、左外连接(LEFT OUTER JOIN)

 

 

左外连接返回从“ON”条件中指定的左侧表中的所有行,只返回满足条件的另一个表中的行。
如下图中所表示:

语法:

SELECT table1.columns, table2.columns  FROM table1  LEFT OUTER JOIN table2  ON table1.common_filed = table2.common_field;


3、右外连接(RIGHT OUTER JOIN)

右外连接返回从“ON”条件中指定的右侧表中的所有行,只返回满足条件的另一个表中的行。
如下图中所表示:

语法:

SELECT table1.columns, table2.columns  
FROM table1  
RIGHT OUTER JOIN table2  
ON table1.common_filed = table2.common_field;
Shell

如下图所示(蓝色部分) -

department 只有三条数据,而employees有多条数据,所以都能满足department的要求!!


4、全连接(FULL OUTER JOIN)

 

FULL外连接从LEFT手表和RIGHT表中返回所有行。 它将NULL置于不满足连接条件的位置。

语法:

SELECT table1.columns, table2.columns  
FROM table1  
FULL OUTER JOIN table2  
ON table1.common_filed = table2.common_field;
Shell

如下图所示(蓝色部分) -

 

没有配置值的全部为空。

5、跨连接(CROSS JOIN)

 

PostgreSQL跨连接(CROSS JOIN)将第一个表的每一行与第二个表的每一行相匹配。 它也被称为笛卡儿积分。 如果table1具有“x”列,而table2具有“y”列,则所得到的表将具有(x + y)列。

语法:


SELECT coloums   
FROM table1   
CROSS JOIN table2

有参考其他的资料!!

 

也可参考:https://www.yiibai.com/postgresql/       

是 ---》 pgAdminIII

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值