天天看点

PostgreSQL连接(JOIN)

PostgreSQL JOIN子句用于把两个或多个表的行结合起来,基于这些表之间的共同变量。

在PostgreSQL中,JOIN有五种连接类型:

CROSS JOIN:交叉连接

内连接:内连接

LEFT OUTER JOIN:左外连接

右外连接:右外连接

FULL OUTER JOIN:全外连接

接下来让我们创建两张表COMPANY和DEPARTMENT。

实例

创建COMPANY表(下载COMPANY SQL文件),数据内容如下:

runoobdb#select * from COMPANY;

id 名称 年龄 地址 薪水
1 保罗 32 加利福尼亚 20000
2 艾伦 25 德州 15000
3 泰迪 23 挪威
4 马克 富蒙德 65000
5 大卫 27 85000
6 22 南厅 45000
7 詹姆斯 24 休斯顿 10000

(7列)

我们往表里添加几条数据:

插入公司价值(8,'Paul',24,'Houston',20000.00);

插入公司值(9,“詹姆斯”,44,“挪威”,5000.00);

插入公司值(10,“詹姆斯”,45,“德州”,5000.00);

此时,COMPANY表的记录如下:

8
9 44 5000
10 45

(10列)

创建一张DEPARTMENT表,添加三个区段:

创建表格部门(

ID INT PRIMARY KEY NOT NULL,

DEPT CHAR(50)NOT NULL,

EMP_ID INT非空

););

向DEPARTMENT表插入三条记录:

插入部门(ID,DEPT,EMP_ID)值(1,'IT Billing',1);(ID ,DEPT ,EMP_ID )VALUES (1 ,'IT Billing' ,1 );

插入部门(ID,DEPT,EMP_ID)值(2,'工程',2);(ID ,DEPT ,EMP_ID )VALUES (2 ,'Engineering' ,2 );

插入部门(ID,DEPT,EMP_ID)值(3,'Finance',7);(ID ,DEPT ,EMP_ID )VALUES (3 ,'Finance' ,7 );

此时,DEPARTMENT表的记录如下:

部门 emp_id
IT帐单 1个1 IT 帐单 1个
工程
财务 73

交叉连接

交叉连接(CROSS JOIN)把第一个表的每一行与第二个表的每一行进行匹配。如果两个输入表分别有x和y行,则结果表有x * y行。

由于交叉连接(CROSS JOIN)有可能产生非常大的表,使用时必须谨慎,只在适当的时候使用它们。

下面是CROSS JOIN的基础语法:

SELECT ... FROM table1交叉联接table2 ...... 来自表1交叉联接表2 ...

基于上面的表,我们可以写一个交叉连接(CROSS JOIN),如下所示:

runoobdb =#从公司交叉联接部门选择EMP_ID,名称,名称;=#从公司交叉联接部门选择EMP_ID ,名称,部门;

得到结果如下:

1 | 保罗| IT账单1 | 保罗| IT 账单    
  1 | 艾伦| IT账单1 | 艾伦| IT 账单   
  1 | 泰迪 IT账单1 | 泰迪| IT 账单   
  1 | 马克| IT账单1 | 马克| IT 账单    
  1 | 大卫| IT账单1 | 大卫| IT 账单   
  1 | 金| IT账单1 | 金| IT 账单     
  1 | 詹姆斯| IT账单1 | 詹姆斯| IT 账单   
  1 | 保罗| IT账单1 | 保罗| IT 账单    
  1 | 詹姆斯| IT账单1 | 詹姆斯| IT 账单   
  1 | 詹姆斯| IT账单1 | 詹姆斯| IT 账单   
  2 | 保罗| 工程2 | 保罗| 工程     
  2 | 艾伦| 工程2 | 艾伦| 工程    
  2 | 泰迪 工程2 | 泰迪| 工程    
  2 | 马克| 工程2 | 马克| 工程     
  2 | 大卫| 工程2 | 大卫| 工程    
  2 | 金| 工程2 | 金| 工程      
  2 | 詹姆斯| 工程2 | 詹姆斯| 工程    
  2 | 保罗| 工程2 | 保罗| 工程     
  2 | 詹姆斯| 工程2 | 詹姆斯| 工程    
  2 | 詹姆斯| 工程2 | 詹姆斯| 工程    
  7 | 保罗| 金融7 | 保罗| 金融                

内连接

内连接(INNER JOIN)根据连接谓词结合两个表(table1和table2)的列值来创建一个新的结果表。查询会把table1中的每一行与table2中的每一行进行比较,找到所有满足连接

手游交易

谓词的行的匹配对。

当满足连接谓词时,A和B行的每个匹配对的列值会合并成一个结果行。

内连接(INNER JOIN)是最常见的连接类型,是另一种的连接类型。

INNER关键字是任选的。

下面是内连接(INNER JOIN)的语法:

选择table1.column1,table2.column2 ...。column1 ,表2 。第2列...

从表1

内联接表2

开启table1.common_filed = table2.common_field;。common_filed = table2 。common_field ;

基于上面的表,我们可以写一个内连接,如下所示:

runoobdb =#从COMPANY.ID = DEPARTMENT.EMP_ID上的公司内部联接部门选择EMP_ID,名称,名称;=#从公司的内部连接部门选择EMP_ID ,名称,部门。ID = 部门。EMP_ID ;

1 | 保罗| IT账单1 | 保罗| IT 账单    
  2 | 艾伦| 工程2 | 艾伦| 工程    
  7 | 詹姆斯| 金融7 | 詹姆斯| 金融               

(3列)(3 行)

左外连接

SQL标准定义了三种类型的外部连接:LEFT,RIGHT和FULL,PostgreSQL支持所有这些。

对于左外连接,首先执行一个内部连接。然后,对于表T1中不满足表T2中连接条件的每一行,其中T2的列中有空值也会添加一个连接行。因此,连接的表在T1中每一行至少有一行。

下面是左外连接(LEFT OUTER JOIN)的基础语法:

SELECT ... FROM table1 LEFT OUTER JOIN table2 ON conditional_expression ...... FROM table1左外部联接table2 ON conditional_expression ...

基于上面两张表,我们可以写个左外连接,如下:

runoobdb =#从COMPANY.ID = DEPARTMENT.EMP_ID上的公司左外加入部门选择EMP_ID,名称,名称;=#从公司的左外连接部门选择EMP_ID ,名称,部门。ID = 部门。EMP_ID ;

1 | 保罗| IT账单1 | 保罗| IT 账单    
  2 | 艾伦| 工程2 | 艾伦| 工程    
  7 | 詹姆斯| 金融7 | 詹姆斯| 金融    
    | 詹姆斯|| 詹姆斯|   
    | 大卫|| 大卫|   
    | 保罗|| 保罗|    
    | 金|| 金|     
    | 马克|| 马克|    
    | 泰迪| 泰迪|   
    | 詹姆斯|| 詹姆斯|              

(10列)(10 行)

右外连接

首先,执行内部连接。然后,对于表T2中不满足表T1中连接条件的每一行,其中T1列中的变量空也会添加一个连接行。这与左联接相反;对于T2中的每一行,结果表总是有一行。

下面是右外连接(RIGHT OUT JOIN)的基本语法:

SELECT ... FROM table1右外连接table2 ON conditional_expression ...... FROM table1右OUTER JOIN table2 ON conditional_expression ...

基于上面两张表,我们建立一个右外连接:

runoobdb =#选择EMP_ID,名称,从COMPANY.ID上的公司右外加入部门中提取; = DEPARTMENT.EMP_ID;=#选择公司的外部联接部门的EMP_ID ,名称,部门。ID = 部门。EMP_ID ;

1 | 保罗| IT账单1 | 保罗| IT 账单    
  2 | 艾伦| 工程2 | 艾伦| 工程    
  7 | 詹姆斯| 金融7 | 詹姆斯| 金融               

外连接

首先,执行内部连接。然后,对于表T1中不满足表T2中任何行连接条件的每一行,如果T2的列中有null值也会添加一个到结果中。中的任何行连接条件的每一行,将会添加T1列中包含null值的到结果中。

下面是外连接的基本语法:

SELECT ... FROM table1 FULL OUTER JOIN table2 ON conditional_expression ...... FROM table1 FULL OUTER JOIN table2 ON conditional_expression ...

基于上面两张表,可以建立一个外连接:

runoobdb =#从COMPANY.ID = DEPARTMENT.EMP_ID上的公司完整外联部门选择EMP_ID,名称,名称。=#从公司的外部联接部门选择EMP_ID ,名称,部门。ID = 部门。EMP_ID ;

1 | 保罗| IT账单1 | 保罗| IT 账单    
  2 | 艾伦| 工程2 | 艾伦| 工程    
  7 | 詹姆斯| 金融7 | 詹姆斯| 金融    
    | 詹姆斯|
    | 大卫|
    | 保罗|
    | 金|
    | 马克|
    | 泰迪
    | 詹姆斯|