0

0

SQL 连接查询语法及使用

php中文网

php中文网

发布时间:2016-06-07 16:21:34

|

1974人浏览过

|

来源于php中文网

原创

一、交叉连接(cross join) 交叉连接(cross join):有两种,显式的和隐式的,不带on子句,返回的是两表的乘积,也叫笛卡尔积。 例如:下面的语句1和语句2的结果是相同的。 语句1:隐式的交叉连接,没有cross join. select o.id, o.order_number, c.id, c.name

   一、交叉连接(cross join)

  交叉连接(cross join):有两种,显式的和隐式的,不带on子句,返回的是两表的乘积,也叫笛卡尔积。

  例如:下面的语句1和语句2的结果是相同的。

  语句1:隐式的交叉连接,没有cross join.

  select o.id, o.order_number, c.id, c.name

  from orders o , customers c

  where o.id=1;

  语句2:显式的交叉连接,使用cross join.

  select o.id,o.order_number,c.id,c.name

  from orders o cross join customers c

  where o.id=1;

  语句1和语句2的结果是相同的,查询结果如下:

  二、内连接(inner join)

  内连接(inner join):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。(所谓的链接表就是数据库在做查询形成的中间表)。

  例如:下面的语句3和语句4的结果是相同的。

  语句3:隐式的内连接,没有inner join,形成的中间表为两个表的笛卡尔积。

  select o.id,o.order_number,c.id,c.name

  from customers c, orders o

  where c.id=o.customer_id;

  语句4:显示的内连接,一般称为内连接,有inner join,形成的中间表为两个表经过on条件过滤后的笛卡尔积。

  select o.id,o.order_number,c.id,c.name

  from customers c inner join orders o on c.id=o.customer_id;

  语句3和语句4的查询结果:

  三、外连接(outer join):

  外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。外连接分三类:左外连接(left outer join)、右外连接(right outer join)和全外连接(full outer join)。

  三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行。不同点如下:

  左外连接还返回左表中不符合连接条件单符合查询条件的数据行。

  右外连接还返回右表中不符合连接条件单符合查询条件的数据行。

  全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即"全外=左外union 右外".

  说明:左表就是在"(left outer join)"关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,outer 关键字是可省略的。

  下面举例说明:

  语句5:左外连接(left outer join)

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o left outer join customers c on c.id=o.customer_id;

  语句6:右外连接(right outer join)

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o right outer join customers c on c.id=o.customer_id;

  注意:where条件放在on后面查询的结果是不一样的。例如:

  语句7:where条件独立。

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o left outer join customers c on c.id=o.customer_id

  where o.order_number'mike_order001';

  语句8:将语句7中的where条件放到on后面。

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o left outer join customers c on c.id=o.customer_id and o.order_number'mike_order001';

  从语句7和语句8查询的结果来看,显然是不相同的,语句8显示的结果是难以理解的。因此,推荐在写连接查询的时候,on后面只跟连接条件,而对中间表限制的条件都写到where子句中。

  语句9:全外连接(full outer join)。

GarbageSort垃圾识别工具箱
GarbageSort垃圾识别工具箱

GarbageSort垃圾识别工具箱是一个基于uni-app开发的微信小程序,使用SpringBoot2搭建后端服务,使用Swagger2构建Restful接口文档,实现了文字查询、语音识别、图像识别其垃圾分类的功能。前端:微信小程序 采用 uni-app 开发框架,uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、H5、以及各

下载

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o full outer join customers c on c.id=o.customer_id;

  注意:mysql是不支持全外的连接的,这里给出的写法适合oracle和db2.但是可以通过左外和右外求合集来获取全外连接的查询结果。下图是上面sql在oracle下执行的结果:

  语句10:左外和右外的合集,实际上查询结果和语句9是相同的。

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o left outer join customers c on c.id=o.customer_id

  union

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o right outer join customers c on c.id=o.customer_id;

  语句9和语句10的查询结果是相同的,如下:

  四、联合连接(union join):

  这是一种很少见的连接方式。oracle、mysql均不支持,其作用是:找出全外连接和内连接之间差异的所有行。这在数据分析中排错中比较常用。也可以利用数据库的集合操作来实现此功能。

  语句11:联合查询(union join)例句,还没有找到能执行的sql环境。

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o union join customers c on c.id=o.customer_id

  语句12:语句11在db2下的等价实现。还不知道db2是否支持语句11呢!

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o full outer join customers c on c.id=o.customer_id

  except

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o inner join customers c on c.id=o.customer_id;

  语句13:语句11在oracle下的等价实现。

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o full outer join customers c on c.id=o.customer_id

  minus

  select o.id,o.order_number,o.customer_id,c.id,c.name

  from orders o inner join customers c on c.id=o.customer_id;

  查询结果如下:

  五、自然连接(natural inner join):

  说真的,这种连接查询没有存在的价值,既然是sql2标准中定义的,就给出个例子看看吧。自然连接无需指定连接列,sql会检查两个表中是否相同名称的列,且假设他们在连接条件中使用,并且在连接条件中仅包含一个连接列。不允许使用on语句,不允许指定显示列,显示列只能用*表示(oracle环境下测 试的)。对于每种连接类型(除了交叉连接外),均可指定natural.下面给出几个例子。

  语句14:

  select *

  from orders o natural inner join customers c;

  语句15:

  select *

  from orders o natural left outer join customers c;

  语句16:

  select *

  from orders o natural right outer join customers c;

  语句17:

  select *

  from orders o natural full outer join customers c;

  六、sql查询的基本原理:两种情况介绍。

  第一、?? 单表查询:根据where条件过滤表中的记录,形成中间表(这个中间表对用户是不可见的);然后根据select的选择列选择相应的列进行返回最终结果。

  第二、?? 两表连接查询:对两表求积(笛卡尔积)并用on条件和连接类型进行过滤形成中间表;然后根据where条件过滤中间表的记录,并根据select指定的列返回查询结果。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

短剧入口地址汇总
短剧入口地址汇总

本专题整合了短剧app推荐平台,阅读专题下面的文章了解更多详细入口。

27

2026.02.03

植物大战僵尸版本入口地址汇总
植物大战僵尸版本入口地址汇总

本专题整合了植物大战僵尸版本入口地址汇总,前往文章中寻找想要的答案。

15

2026.02.03

c语言中/相关合集
c语言中/相关合集

本专题整合了c语言中/的用法、含义解释。阅读专题下面的文章了解更多详细内容。

3

2026.02.03

漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题
漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题

本专题围绕漫蛙漫画(Manwa / Manwa2)官网网页版入口进行整理,涵盖漫蛙漫画官方主页访问方式、网页版在线阅读入口、台版正版漫画浏览说明及基础使用指引,帮助用户快速进入漫蛙漫画官网,稳定在线阅读正版漫画内容,避免误入非官方页面。

13

2026.02.03

Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口
Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口

本专题汇总了俄罗斯知名搜索引擎 Yandex 的官网入口、免登录访问地址、中文登录方法与网页版使用指南,帮助用户稳定访问 Yandex 官网,并提供一站式入口汇总。无论是登录入口还是在线搜索,用户都能快速获取最新稳定的访问链接与使用指南。

114

2026.02.03

Java 设计模式与重构实践
Java 设计模式与重构实践

本专题专注讲解 Java 中常用的设计模式,包括单例模式、工厂模式、观察者模式、策略模式等,并结合代码重构实践,帮助学习者掌握 如何运用设计模式优化代码结构,提高代码的可读性、可维护性和扩展性。通过具体示例,展示设计模式如何解决实际开发中的复杂问题。

3

2026.02.03

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

2

2026.02.03

Python 强化学习与深度Q网络(DQN)
Python 强化学习与深度Q网络(DQN)

本专题深入讲解 Python 在强化学习(Reinforcement Learning)中的应用,重点介绍 深度Q网络(DQN) 及其实现方法,涵盖 Q-learning 算法、深度学习与神经网络的结合、环境模拟与奖励机制设计、探索与利用的平衡等。通过构建一个简单的游戏AI,帮助学习者掌握 如何使用 Python 训练智能体在动态环境中作出决策。

3

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 8.4万人学习

Java 教程
Java 教程

共578课时 | 56.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号