搜索
首页数据库mysql教程SQL 连接查询语法及使用

一、交叉连接(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)。

  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指定的列返回查询结果。

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
解释InnoDB缓冲池及其对性能的重要性。解释InnoDB缓冲池及其对性能的重要性。Apr 19, 2025 am 12:24 AM

InnoDBBufferPool通过缓存数据和索引页来减少磁盘I/O,提升数据库性能。其工作原理包括:1.数据读取:从BufferPool中读取数据;2.数据写入:修改数据后写入BufferPool并定期刷新到磁盘;3.缓存管理:使用LRU算法管理缓存页;4.预读机制:提前加载相邻数据页。通过调整BufferPool大小和使用多个实例,可以优化数据库性能。

MySQL与其他编程语言:一种比较MySQL与其他编程语言:一种比较Apr 19, 2025 am 12:22 AM

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

学习MySQL:新用户的分步指南学习MySQL:新用户的分步指南Apr 19, 2025 am 12:19 AM

MySQL值得学习,因为它是强大的开源数据库管理系统,适用于数据存储、管理和分析。1)MySQL是关系型数据库,使用SQL操作数据,适合结构化数据管理。2)SQL语言是与MySQL交互的关键,支持CRUD操作。3)MySQL的工作原理包括客户端/服务器架构、存储引擎和查询优化器。4)基本用法包括创建数据库和表,高级用法涉及使用JOIN连接表。5)常见错误包括语法错误和权限问题,调试技巧包括检查语法和使用EXPLAIN命令。6)性能优化涉及使用索引、优化SQL语句和定期维护数据库。

MySQL:初学者的基本技能MySQL:初学者的基本技能Apr 18, 2025 am 12:24 AM

MySQL适合初学者学习数据库技能。1.安装MySQL服务器和客户端工具。2.理解基本SQL查询,如SELECT。3.掌握数据操作:创建表、插入、更新、删除数据。4.学习高级技巧:子查询和窗口函数。5.调试和优化:检查语法、使用索引、避免SELECT*,并使用LIMIT。

MySQL:结构化数据和关系数据库MySQL:结构化数据和关系数据库Apr 18, 2025 am 12:22 AM

MySQL通过表结构和SQL查询高效管理结构化数据,并通过外键实现表间关系。1.创建表时定义数据格式和类型。2.使用外键建立表间关系。3.通过索引和查询优化提高性能。4.定期备份和监控数据库确保数据安全和性能优化。

MySQL:解释的关键功能和功能MySQL:解释的关键功能和功能Apr 18, 2025 am 12:17 AM

MySQL是一个开源的关系型数据库管理系统,广泛应用于Web开发。它的关键特性包括:1.支持多种存储引擎,如InnoDB和MyISAM,适用于不同场景;2.提供主从复制功能,利于负载均衡和数据备份;3.通过查询优化和索引使用提高查询效率。

SQL的目的:与MySQL数据库进行交互SQL的目的:与MySQL数据库进行交互Apr 18, 2025 am 12:12 AM

SQL用于与MySQL数据库交互,实现数据的增、删、改、查及数据库设计。1)SQL通过SELECT、INSERT、UPDATE、DELETE语句进行数据操作;2)使用CREATE、ALTER、DROP语句进行数据库设计和管理;3)复杂查询和数据分析通过SQL实现,提升业务决策效率。

初学者的MySQL:开始数据库管理初学者的MySQL:开始数据库管理Apr 18, 2025 am 12:10 AM

MySQL的基本操作包括创建数据库、表格,及使用SQL进行数据的CRUD操作。1.创建数据库:CREATEDATABASEmy_first_db;2.创建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入数据:INSERTINTObooks(title,author,published_year)VA

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)