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