PostgreSQL 数据库连接

在PostgreSQL中,有以下类型的连接:

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

PostgreSQL内部连接也被称为连接或简单连接。 这是最常见的连接类型。 此连接返回满足连接条件的多个表中的所有行。

如图所示:

PostgreSQL 数据库连接_第1张图片

语法:

SELECT table1.columns, table2.columns  
FROM table1  
INNER JOIN table2  
ON table1.common_filed = table2.common_field;
2、左外连接(LEFT OUTER JOIN)

左外连接返回从“ON”条件中指定的左侧表中的所有行,只返回满足条件的另一个表中的行。
如下图中所表示:
PostgreSQL 数据库连接_第2张图片

语法:

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

3、右外连接(RIGHT OUTER JOIN)

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

如下图所示(蓝色部分) -
PostgreSQL 数据库连接_第3张图片

语法:

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

4、全外连接(FULL OUTER JOIN)

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

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

PostgreSQL 数据库连接_第4张图片

语法:

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



转自:http://www.yiibai.com/postgresql/what-is-postgresql.html

你可能感兴趣的:(数据库)