欢迎来到夜的世界

莫听穿林打叶声,何妨吟啸且徐行。竹杖芒鞋轻胜马,谁怕?一蓑烟雨任平生.料峭春风吹酒醒,微冷,山头斜照却相迎。回首向来萧瑟处,归去,也无风雨也无晴。
扩大
缩小

postgres数据库之连接

一、分类

内连接(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;

 注意 : 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;

 注意 : 没有配置值的全部为空 

 

5、跨连接(CROSS JOIN)

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

语法 : 

 SELECT coloums   
FROM table1   
CROSS JOIN table2

 

posted on 2020-05-14 15:21  二十四桥_明月夜  阅读(1045)  评论(0编辑  收藏  举报

导航