PostgreSQL 连接 inner join on

本文详细介绍了PostgreSQL数据库中的五种连接方式:内连接、左外连接、右外连接、全连接及跨连接,并提供了每种连接类型的定义、应用场景及语法示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

<think>好的,用户想知道如何在PostgreSQL中使用INNER JOIN进行查询,包括方法、示例和语法。首先,我需要回顾INNER JOIN的基本概念,确保自己理解正确。INNER JOIN用于根据两个或多个表之间的共同字段组合行,只返回匹配的行。 接下来,我需要参考用户提供的引用内容。根据引用[1],PostgreSQLJOIN类型包括INNER JOIN,并且提到INNER JOIN是内连接,基于共同字段。引用[2]提到了可以在ON子句中使用函数处理连接条件,还有USING子句的用法。引用[3]展示了UPDATE结合JOIN的语法,虽然用户问的是SELECT,但可能语法结构有相似之处。 用户需要具体的语法和示例。首先,我应该写出INNER JOIN的标准语法结构,包括使用ON和USING两种方式。然后,给出具体的例子,比如两个表(比如员工表和部门表)的连接,展示如何查询员工及其所属部门的信息。可能需要包括字段选择、别名使用,以及如何处理连接条件中的大小写不一致问题,如使用UPPER函数,如引用[2]所示。 还要考虑用户可能的深层需求,比如性能优化或常见错误,但用户目前主要问的是使用方法,所以示例要清晰易懂。需要确保语法正确,比如在PostgreSQL中是否正确使用JOIN关键字,是否需要特定的子句结构。此外,是否需要提到WHERE子句与JOIN的区别,比如显式INNER JOIN vs 隐式连接。 可能需要检查是否遗漏了任何关键点,比如多表连接的情况,或者如何处理重复字段。不过用户的问题集中在INNER JOIN的基础使用上,所以保持示例简单明了。最后,生成相关问题时要围绕INNER JOIN的扩展应用、优化方法、与其他JOIN类型的区别等,帮助用户进一步学习。</think>在 PostgreSQL 中,`INNER JOIN` 用于根据两个表之间的共同字段返回匹配的行,是应用最广泛的连接类型之一[^1]。以下是具体用法和示例: --- ### **INNER JOIN 语法** ```sql SELECT 列名列表 FROM 表1 INNER JOIN 表2 ON 表1.共同字段 = 表2.共同字段; ``` 或使用 `USING` 子句简化(当字段名相同时): ```sql SELECT 列名列表 FROM 表1 INNER JOIN 表2 USING (共同字段名); ``` --- ### **示例场景** 假设有两个表: - **employees 表**:`id`, `name`, `department_id` - **departments 表**:`id`, `department_name` #### 示例 1:基本 INNER JOIN 查询所有员工及其所属部门名称: ```sql SELECT e.name AS 员工姓名, d.department_name AS 部门名称 FROM employees e INNER JOIN departments d ON e.department_id = d.id; ``` #### 示例 2:使用 USING 子句 若连接字段名相同(例如都叫 `id`): ```sql SELECT e.name, d.department_name FROM employees e INNER JOIN departments d USING (department_id); ``` #### 示例 3:结合 WHERE 子句过滤 查询特定部门的员工: ```sql SELECT e.name, d.department_name FROM employees e INNER JOIN departments d ON e.department_id = d.id WHERE d.department_name = '技术部'; ``` #### 示例 4:处理字段不一致(使用函数) 若字段大小写不一致,可用函数统一格式[^2]: ```sql SELECT e.name, d.department_name FROM employees e INNER JOIN departments d ON UPPER(e.department_code) = UPPER(d.dept_code); ``` --- ### **关键点** 1. **匹配原则**:仅返回两个表中字段匹配的行。 2. **性能优化**:确保连接字段有索引以提高查询速度。 3. **多表连接**:可连续使用 `INNER JOIN` 连接多个表。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值