SQL中的表格连接

本文介绍了SQL中表格连接的概念,包括INNER JOIN、自然连接Natural JOIN和OUTER JOIN。通过示例展示了如何使用这些连接方式从多个表格中获取所需列信息,以实现数据的综合展示。

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

SQL表格连接(joining tables)

SQL表格连接是非常常用的功能,使用表格连接可以同时从多个表格中获得想要的列。
举个简单的例子说明。
现在有两个表格,第一个表格名为t1,它储存了员工id(employee_id)和员工岗位(employee_position)两列信息。

第二个表格名为t2,他储存了员工id(employee_id)、员工电话(employee_phone)和员工地址(employee_address)三列信息。

现在想要通过一个SELECT语句展示employee_id、employee_position、employee_phone和employee_address四列信息(也就是从多个表中获取列信息),该如何操作?这里就需要用到SQL表格连接的相关知识了。

  1. 首先介绍的是INNER JOIN的连接方式:
--INNER JOIN
SELECT t1.employee_id, t1.employee_position, t2.employee_phone, t2.employee_address
FROM t1,t2
WHERE t1.employee_id = t2.employee_id; --对两表中employee_id相同的行进行连接
--INNER JOIN的另一个写法
SELECT t1.employee_id, t1.employee_position, t2.employee_phone, t2.employee_address
FROM t1
INNER JOIN t2 ON t1.employee_id = t2.employee_id; --在ON之后输入筛选条件(就是上一块代码中WHERE后面的条件)

输出结果如下图所示:

可以看到,我们成功地将来自t1和t2两个表格的employee_id、employee_position、employee_phone和employee_address四列信息同时展示出来。值得注意的是,INNER JOIN的连接方式是只选取两个表格中的重叠部分进行连接,这就是为什么具有4行数据的t1和具有3行数据的t2经连接之后形成只有3行的数据。

  1. 自然连接Natural JOIN的连接方式

自然连接不需要指定具体的连接方式,系统会自动判断参与连接的表格是否具有相同的列和对应的数据类型,然后自行连接。若参与连接的表格没有相同名称的列或者该列的数据类型不一致,那么系统会报错。

SELECT t1.employee_id, t1.employee_position, t2.employee_phone, t2.employee_address
FROM t1
NATURAL JOIN t2; --不需要指定连接方式
  1. OUTER JOIN

外连接也是非常常用的一种连接方式,根据这种连接方式,我们可以将表格t1中的employee_id作为列的基准,不管t2中是否有该列所有行的对应关系。

--OUTER JOIN
SELECT t1.employee_id, t1.employee_position, t2.employee_phone, t2.employee_address
FROM t1
LEFT OUTER JOIN t2 ON t1.employee_id = t2.employee_id; --LEFT OUTER JOIN指的是以左边的t1的对应列为连接后的列的基准

同样的还有RIGHT OUTER JOIN,与LEFT OUTER JOIN正好相反,它指的是以其右边的表格的对应列作为连接后的列的基准。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值