SQL中的连接查询详解


Posted in SQL Server onJune 21, 2022

Join 连接 (SQL Join)

SQL Join (连接) 是利用不同数据表之间字段的关连性来结合多数据表之检索。

SQL Join是结合多个数据表而组成一抽象的暂时性数据表以供数据查询,在原各数据表中之纪录及结构皆不会因此连接查询而改变。

这是一个客户数据表「customers」:

C_Id

Name

City

Address

Phone

1

张一

台北市

XX路100号

02-12345678

2

王二

新竹县

YY路200号

03-12345678

3

李三

高雄县

ZZ路300号

07-12345678

而这是产品订单的数据表「orders」:

O_Id

OrderNo

C_Id

1

2572

3

2

7375

3

3

7520

1

4

1054

1

5

1257

5

其中,C_Id 是客户数据表中的主键 (Primary Key) 字段,我们怎么将这两张不同的数据表依相关字段来作个连接结合以便查询呢?这就是接下来的主题 Join!

SQL 的 Join 查询有哪几种类型?

  • Inner Join : 内部连接

  • LEFT (OUTER) JOIN : 左外部连接

  • RIGHT (OUTER) JOIN : 右外部连接

  • FULL (OUTER) JOIN : 全部外部连接

  • CROSS JOIN : 交叉连接

  • NATURAL JOIN : 自然连接

INNER JOIN - 内部连接

INNER JOIN (内部连接) 为等值连接,必需指定等值连接的条件,而查询结果只会返回符合连接条件的数据。

INNER JOIN 语法 (SQL INNER JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
INNER JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

SELECT table_column1, table_column2···
FROM table_name1
INNER JOIN table_name2
USING (column_name);

INNER JOIN 查询实例 (Example)

现在我们想列出所有客户的订单编号数据,我们可以作一个 INNER JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
INNER JOIN orders
ON customers.C_Id=orders.C_Id;

其中用点号连接之「XXX.YYY」表示XXX数据表中的YYY字段。

查询结果如下:

Name

Order_No

李三

2572

李三

7375

张一

7520

张一

1054

查询结果只会返回符合连接条件的数据!

LEFT JOIN - 左外部连接

LEFT JOIN 可以用来建立左外部连接,查询的 SQL 叙述句 LEFT JOIN 左侧数据表 (table_name1) 的所有记录都会加入到查询结果中,即使右侧数据表 (table_name2) 中的连接字段没有符合的值也一样。

LEFT JOIN 语法 (SQL LEFT JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
LEFT JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

有些数据库的语法会是LEFT OUTER JOIN。

LEFT JOIN 查询实例 (Example)

现在我们想查询所有客户与其订单状况的数据,我们可以作一个 LEFT JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
LEFT JOIN orders
ON customers.C_Id=orders.C_Id;

查询结果如下:

Name

Order_No

张一

7520

张一

1054

王二

 

李三

2572

李三

7375

LEFT JOIN会返回左侧数据表中所有数据列,就算没有符合连接条件,而右侧数据表中如果没有匹配的数据值就会显示为「NULL」。

RIGHT JOIN - 右外部连接

相对于LEFT JOIN,RIGHT JOIN 可以用来建立右外部连接,查询的 SQL 叙述句 RIGHT JOIN 右侧数据表 (table_name2) 的所有记录都会加入到查询结果中,即使左侧数据表 (table_name2) 中的连接字段没有符合的值也一样。

RIGHT JOIN 语法 (SQL RIGHT JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
RIGHT JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

有些数据库的语法会是RIGHT OUTER JOIN。

RIGHT JOIN 查询实例 (Example)

现在我们想查询所有订单与相应的客户之资料,我们可以作一个 RIGHT JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
RIGHT JOIN orders
ON customers.C_Id=orders.C_Id;

查询结果如下:

Name

Order_No

李三

2572

李三

7375

张一

7520

张一

1054

 

1257

RIGHT JOIN会返回右侧数据表中所有数据列,就算是没有符合连接条件,而左侧数据表中如果没有匹配的数据值就会显示为「NULL」。

FULL JOIN - 全部外部连接

FULL JOIN 即为 LEFT JOIN 与 RIGHT JOIN 的联集,它会返回左右数据表中所有的纪录,不论是否符合连接条件。

FULL JOIN 语法 (SQL FULL JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
FULL JOIN table_name2
ON table_name1.column_name=table_name2.column_name;

FULL JOIN 查询实例 (Example)

我们来作一个 FULL JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
FULL JOIN orders
ON customers.C_Id=orders.C_Id;

查询结果如下:

Name

Order_No

李三

2572

李三

7375

张一

7520

张一

1054

 

1257

王二

 

MySQL数据库中没有FULL JOIN,但是您可以用UNION来模拟。

CROSS JOIN - 交叉连接

交叉连接为两个数据表间的笛卡儿乘积 (Cartesian product),两个数据表在结合时,不指定任何条件,即将两个数据表中所有的可能排列组合出来,以下例而言 CROSS JOIN 出来的结果资料列数为 3×5=15 笔,因此,当有WHERE、ON、USING条件时不建议使用。

CROSS JOIN 语法 (SQL CROSS JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
CROSS JOIN table_name2;

SELECT table_column1, table_column2···
FROM table_name1, table_name2;

SELECT table_column1, table_column2···
FROM table_name1
JOIN table_name2;

FULL JOIN 查询实例 (Example)

这是一个客户数据表「customers」:

C_Id

Name

City

Address

Phone

1

张一

台北市

XX路100号

02-12345678

2

王二

新竹县

YY路200号

03-12345678

3

李三

高雄县

ZZ路300号

07-12345678

而这是产品订单的数据表「orders」:

O_Id

Order_No

C_Id

1

2572

3

2

7375

3

3

7520

1

4

1054

1

5

1257

5

我们来作一个 CROSS JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
CROSS JOIN orders;

查询结果如下:

Name

Order_No

张一

2572

王二

2572

李三

2572

张一

7375

王二

7375

李三

7375

张一

7520

王二

7520

李三

7520

张一

1054

王二

1054

李三

1054

张一

1257

王二

1257

李三

1257

NATURAL JOIN - 自然连接

自然连接有 NATURAL JOIN、NATURAL LEFT JOIN、NATURAL RIGHT JOIN,两个表格在进行 JOIN 时,加上 NATURAL 这个关键词之后,两数据表之间同名的字段会被自动结合在一起。

NATURAL JOIN 语法 (SQL NATURAL JOIN Syntax)

SELECT table_column1, table_column2···
FROM table_name1
NATURAL JOIN table_name2;

NATURAL JOIN 查询实例 (Example)

这是一个客户数据表「customers」:

C_Id

Name

City

Address

Phone

1

张一

台北市

XX路100号

02-12345678

2

王二

新竹县

YY路200号

03-12345678

3

李三

高雄县

ZZ路300号

07-12345678

而这是产品订单的数据表「orders」:

O_Id

Order_No

C_Id

1

2572

3

2

7375

3

3

7520

1

4

1054

1

5

1257

5

现在我们想列出所有客户的订单编号数据,我们可以作一个 NATURAL JOIN 查询:

SELECT customers.Name, orders.Order_No
FROM customers
NATURAL JOIN orders;

查询结果如下:

Name

Order_No

李三

2572

李三

7375

张一

7520

张一

1054

注意到了吗?返回结果同等于下面这个INNER JOIN查询:

SELECT customers.Name, orders.Order_No
FROM customers
INNER JOIN orders
ON customers.C_Id=orders.C_Id;

到此这篇关于SQL连接查询的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

SQL Server 相关文章推荐
SQLServer中JSON文档型数据的查询问题解决
Jun 27 SQL Server
SQL Server作业失败:无法确定所有者是否有服务器访问权限的解决方法
Jun 30 SQL Server
SQL语句中JOIN的用法场景分析
Jul 25 SQL Server
sql server删除前1000行数据的方法实例
Aug 30 SQL Server
Windows环境下实现批量执行Sql文件
Oct 05 SQL Server
Spark SQL 2.4.8 操作 Dataframe的两种方式
Oct 16 SQL Server
详解在SQLPlus中实现上下键翻查历史命令的功能
Mar 18 SQL Server
SQLServer权限之只开启创建表权限
Apr 12 SQL Server
SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询
May 25 SQL Server
SQL Server删除表中的重复数据
May 25 SQL Server
SQL Server携程核心系统无感迁移到MySQL实战
Jun 01 SQL Server
在SQL Server中使用 Try Catch 处理异常的示例详解
Jul 15 SQL Server
SQL Server数据库备份和恢复数据库的全过程
一次SQL查询优化原理分析(900W+数据从17s到300ms)
Jun 10 #SQL Server
SQL Server2019安装的详细步骤实战记录(亲测可用)
SQL Server携程核心系统无感迁移到MySQL实战
SQL解决未能删除约束问题drop constraint
May 30 #SQL Server
SQL使用复合索引实现数据库查询的优化
May 25 #SQL Server
SQL Server中的逻辑函数介绍
May 25 #SQL Server
You might like
PHP分页显示制作详细讲解
2006/10/09 PHP
图片存储与浏览一例(Linux+Apache+PHP+MySQL)
2006/10/09 PHP
php获取目录中所有文件名及判断文件与目录的简单方法
2017/03/04 PHP
PHP里面把16进制的图片数据显示在html的img标签上(实现方法)
2017/05/02 PHP
PHP一致性hash分布式算法封装类定义与用法示例
2018/08/04 PHP
Laravel+Intervention实现上传图片功能示例
2019/07/09 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
2020/02/27 PHP
javascript拓展DOM操作 prependChild insertAfert
2010/11/17 Javascript
script标签属性type与language使用选择
2012/12/02 Javascript
jQuery实现Div拖动+键盘控制综合效果的方法
2015/03/10 Javascript
javascript实现英文首字母大写
2015/04/23 Javascript
jQuery获取URL请求参数的方法
2015/07/18 Javascript
基于javascript简单实现对身份证校验
2021/01/25 Javascript
JavaScript希尔排序、快速排序、归并排序算法
2016/05/08 Javascript
浅谈bootstrap源码分析之scrollspy(滚动侦听)
2016/06/06 Javascript
jQuery实现的选择商品飞入文本框动画效果完整实例
2016/08/10 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
jQuery对table表格进行增删改查
2020/12/22 Javascript
详解Vue中一种简易路由传参办法
2017/09/15 Javascript
编写React组件项目实践分析
2018/03/04 Javascript
小程序实现左右来回滚动字幕效果
2018/12/28 Javascript
JS数组push、unshift、pop、shift方法的实现与使用方法示例
2020/04/29 Javascript
Javascript中Math.max和Math.max.apply的区别和用法详解
2020/08/24 Javascript
JavaScript 如何在浏览器中使用摄像头
2020/12/02 Javascript
[03:02]安得倚天剑,跨海斩长鲸——中国军团出征DOTA2国际邀请赛
2018/08/14 DOTA
python使用smtplib模块通过gmail实现邮件发送的方法
2015/05/08 Python
利用python将json数据转换为csv格式的方法
2018/03/22 Python
Django使用Mysql数据库已经存在的数据表方法
2018/05/27 Python
Python实现钉钉/企业微信自动打卡的示例代码
2021/02/02 Python
html5 svg 中元素点击事件添加方法
2013/01/16 HTML / CSS
简述数据库的设计过程
2015/06/22 面试题
保护黄河倡议书
2014/05/16 职场文书
房屋买卖定金协议书
2016/03/21 职场文书
合理缓解职场压力,让你随时保持最佳状态!
2019/06/21 职场文书
详解Redis基本命令与使用场景
2021/06/01 Redis
使用Mysql计算地址的经纬度距离和实时位置信息
2022/04/29 MySQL