数据的连接与关联查询

INNER JOIN

INNER JOIN是MySQL中的一种表连接操作,用于将两个或多个表中的行基于一个共同的列进行匹配,并返回匹配的结果集。

下面是一个案例,假设有两个表:orders和customers,分别存储订单信息和客户信息。表结构如下:

orders表:

+----+---------+------------+
| id | order_no| customer_id|
+----+---------+------------+
| 1 | 1001 | 1 |
| 2 | 1002 | 2 |
| 3 | 1003 | 1 |
+----+---------+------------+

customers表:

+----+---------+
| id | name |
+----+---------+
| 1 | Alice |
| 2 | Bob |
| 3 | Charlie |
+----+---------+

现在我们想要查询订单表中的订单号和对应的客户名字,可以使用INNER JOIN来实现。SQL语句如下:

SELECT orders.order_no, customers.name
FROM orders
INNER JOIN customers ON orders.customer_id = customers.id;

解释SQL语句:

- SELECT orders.order_no, customers.name:选择要查询的列,即订单号和客户名字。

- FROM orders:指定要查询的主表为orders表。

- INNER JOIN customers:指定要连接的表为customers表,并使用INNER JOIN进行连接操作。

- ON orders.customer_id = customers.id:指定连接条件,即orders表的customer_id列与customers表的id列进行匹配。

- 最终返回匹配的结果集,包含订单号和对应的客户名字。

执行以上SQL语句后,将返回以下结果:

+---------+---------+
| order_no| name |
+---------+---------+
| 1001 | Alice |
| 1002 | Bob |
| 1003 | Alice |
+---------+---------+

结果集中的每一行表示一个订单和对应的客户名字。

LEFT JION

LEFT JOIN是MySQL中的一种表连接操作,用于将左表中的所有行与右表中的匹配行进行连接,并返回匹配的结果集。如果右表中没有匹配的行,则返回NULL值。

以下是一个案例,假设有两个表:orders和customers,分别存储订单信息和客户信息。表结构与之前的案例相同。

现在我们想要查询订单表中的订单号和对应的客户名字,包括没有匹配的订单。可以使用LEFT JOIN来实现。SQL语句如下:

SELECT orders.order_no, customers.name
FROM orders
LEFT JOIN customers ON orders.customer_id = customers.id;

解释SQL语句:

- SELECT orders.order_no, customers.name:选择要查询的列,即订单号和客户名字。

- FROM orders:指定要查询的主表为orders表。

- LEFT JOIN customers:指定要连接的表为customers表,并使用LEFT JOIN进行连接操作。

- ON orders.customer_id = customers.id:指定连接条件,即orders表的customer_id列与customers表的id列进行匹配。

- 最终返回匹配的结果集,包含订单号和对应的客户名字。如果没有匹配的行,则客户名字列的值为NULL。

执行以上SQL语句后,将返回以下结果:

+---------+---------+
| order_no| name |
+---------+---------+
| 1001 | Alice |
| 1002 | Bob |
| 1003 | Alice |
+---------+---------+

结果集中的每一行表示一个订单和对应的客户名字。如果订单没有对应的客户信息,则客户名字列的值为NULL。

RIGHT JOIN

RIGHT JOIN是MySQL中的一种表连接操作,用于将右表中的所有行与左表中的匹配行进行连接,并返回匹配的结果集。如果左表中没有匹配的行,则返回NULL值。

以下是一个案例,假设有两个表:orders和customers,分别存储订单信息和客户信息。表结构与之前的案例相同。

现在我们想要查询客户表中的客户名字和对应的订单号,包括没有匹配的客户。可以使用RIGHT JOIN来实现。SQL语句如下:

SELECT orders.order_no, customers.name
FROM orders
RIGHT JOIN customers ON orders.customer_id = customers.id;

解释SQL语句:

- SELECT orders.order_no, customers.name:选择要查询的列,即订单号和客户名字。

- FROM orders:指定要查询的主表为orders表。

- RIGHT JOIN customers:指定要连接的表为customers表,并使用RIGHT JOIN进行连接操作。

- ON orders.customer_id = customers.id:指定连接条件,即orders表的customer_id列与customers表的id列进行匹配。

- 最终返回匹配的结果集,包含客户名字和对应的订单号。如果没有匹配的行,则订单号列的值为NULL。

执行以上SQL语句后,将返回以下结果:

+---------+---------+
| order_no| name |
+---------+---------+
| 1001 | Alice |
| 1002 | Bob |
| 1003 | Alice |
+---------+---------+

结果集中的每一行表示一个客户和对应的订单号。如果客户没有对应的订单信息,则订单号列的值为NULL。

FULL JOIN

FULL JOIN是MySQL中的一种表连接操作,用于将左表和右表中的所有行进行连接,并返回匹配的结果集。如果左表或右表中没有匹配的行,则返回NULL值。

以下是一个案例,假设有两个表:orders和customers,分别存储订单信息和客户信息。表结构与之前的案例相同。

现在我们想要查询所有的订单和客户信息,包括没有匹配的行。可以使用FULL JOIN来实现。SQL语句如下:

SELECT orders.order_no, customers.name
FROM orders
FULL JOIN customers ON orders.customer_id = customers.id;

解释SQL语句:

- SELECT orders.order_no, customers.name:选择要查询的列,即订单号和客户名字。

- FROM orders:指定要查询的主表为orders表。

- FULL JOIN customers:指定要连接的表为customers表,并使用FULL JOIN进行连接操作。

- ON orders.customer_id = customers.id:指定连接条件,即orders表的customer_id列与customers表的id列进行匹配。

- 最终返回匹配的结果集,包含订单号和对应的客户名字。如果没有匹配的行,则订单号或客户名字列的值为NULL。

执行以上SQL语句后,将返回以下结果:

+---------+---------+
| order_no| name |
+---------+---------+
| 1001 | Alice |
| 1002 | Bob |
| 1003 | Alice |
| NULL | Charlie |
+---------+---------+

结果集中的每一行表示一个订单和对应的客户名字。如果订单或客户没有对应的匹配行,则订单号或客户名字列的值为NULL。

数据的多表操作

UNION操作符

UNION是MySQL中的一种集合操作,用于将多个SELECT语句的结果合并成一个结果集,并去除重复的行。

以下是一个案例,假设有两个表:orders1和orders2,分别存储不同时间段的订单信息。表结构如下:

orders1表:

+----+---------+
| id | order_no|
+----+---------+
| 1 | 1001 |
| 2 | 1002 |
| 3 | 1003 |
+----+---------+

orders2表:

+----+---------+
| id | order_no|
+----+---------+
| 4 | 1004 |
| 5 | 1005 |
| 6 | 1006 |
+----+---------+

现在我们想要查询两个表中的所有订单号,并合并成一个结果集。可以使用UNION来实现。SQL语句如下:

SELECT order_no FROM orders1
UNION
SELECT order_no FROM orders2;

解释SQL语句:

- SELECT order_no FROM orders1:选择要查询的列,即orders1表中的订单号。

- UNION:使用UNION操作符将两个SELECT语句的结果合并。

- SELECT order_no FROM orders2:选择要查询的列,即orders2表中的订单号。

- 最终返回合并后的结果集,包含两个表中的所有订单号,并去除重复的行。

执行以上SQL语句后,将返回以下结果:

+---------+
| order_no|
+---------+
| 1001 |
| 1002 |
| 1003 |
| 1004 |
| 1005 |
| 1006 |
+---------+

结果集中的每一行表示一个订单号,包括两个表中的所有订单号,并去除了重复的行。

EXISTS 关键字

EXISTS是MySQL中的一个条件操作符,用于检查一个子查询是否返回任何行。如果子查询返回至少一行,则条件成立,返回TRUE;否则,条件不成立,返回FALSE。

以下是一个案例,假设有两个表:orders和customers,分别存储订单信息和客户信息。表结构与之前的案例相同。

现在我们想要查询存在至少一个订单的客户信息。可以使用EXISTS来实现。SQL语句如下:

SELECT *
FROM customers
WHERE EXISTS (
SELECT 1
FROM orders
WHERE orders.customer_id = customers.id
);

解释SQL语句:

- SELECT * FROM customers:选择要查询的表为customers表,即查询客户信息。

- WHERE EXISTS (...):使用EXISTS条件操作符来判断是否存在满足条件的子查询结果。

- SELECT 1 FROM orders WHERE orders.customer_id = customers.id:子查询,查询orders表中是否存在与customers表中的id匹配的订单。

- 最终返回满足条件的客户信息。

执行以上SQL语句后,将返回存在至少一个订单的客户信息。

注意:在实际使用中,可以根据具体需求选择需要查询的列,而不是使用通配符*来查询所有列。

IN关键字

IN是MySQL中的一个条件操作符,用于判断一个值是否存在于一个列表或子查询的结果中。如果值存在于列表或子查询的结果中,则条件成立,返回TRUE;否则,条件不成立,返回FALSE。

以下是一个案例,假设有一个表:orders,存储订单信息。表结构如下:

orders表:

+----+---------+
| id | order_no|
+----+---------+
| 1 | 1001 |
| 2 | 1002 |
| 3 | 1003 |
+----+---------+

现在我们想要查询订单号为1001和1003的订单信息。可以使用IN来实现。SQL语句如下:

SELECT *
FROM orders
WHERE order_no IN (1001, 1003);

解释SQL语句:

- SELECT * FROM orders:选择要查询的表为orders表,即查询订单信息。

- WHERE order_no IN (1001, 1003):使用IN条件操作符来判断订单号是否存在于指定的列表中。

- (1001, 1003):指定一个列表,包含要匹配的订单号。

- 最终返回满足条件的订单信息。

执行以上SQL语句后,将返回订单号为1001和1003的订单信息。

注意:IN操作符也可以与子查询一起使用,用于判断一个值是否存在于子查询的结果中。例如,可以将(1001, 1003)替换为一个子查询,来动态地获取要匹配的订单号。

【技术积累】Mysql中的SQL语言【技术篇】【四】的更多相关文章

  1. MySQL中的SQL语言

    从功能上划分,SQL 语言可以分为DDL,DML和DCL三大类.1. DDL(Data Definition Language)数据定义语言,用于定义和管理 SQL 数据库中的所有对象的语言 :CRE ...

  2. MySQL入门——MySQL数据库和SQL语言

    MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...

  3. MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause

    MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause 201 ...

  4. 浅谈MySQL中优化sql语句查询常用的30种方法 - 转载

    浅谈MySQL中优化sql语句查询常用的30种方法 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使 ...

  5. 【原创】6. 在MYSQL++中实现SQL语法中的NULL

    这次要说明的是在MYSQL++中为了实现SQL中的NULL而做出的一系列的举措.我的感觉是Null<T, B>类型通常出现在SSQLS和template Query中比较多. 1. 什么是 ...

  6. Mysql中的sql是如何执行的 --- 极客时间学习笔记

    MySQL中的SQL是如何执行的 MySQL是典型的C/S架构,也就是Client/Server架构,服务器端程序使用的mysqld.整体的MySQL流程如下图所示: MySQL是有三层组成: 连接层 ...

  7. MySQL中的SQL的常见优化策略

    MySQL中的SQL的常见优化策略 MySQL中的索引优化 MySQL中的索引简介 1 避免全表扫描对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索 ...

  8. ORCAL 数据库的约束以及SQL语言的四种类型

    oracle数据库约束: 定义:要输入的这个值是一个什么样的值, 或者是哪个范围内的值 作用: 确保完整性, 确保精确性 1, 非空约束(not null) 记录一条信息的时候如果用户名和密码没有被记 ...

  9. 【MySQL笔记】SQL语言四大类语言

     SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL.   1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句, ...

  10. mysql数据库基本操作sql语言

    mysql的启动与关闭 启动 /etc/init.d/mysql start 多实例使用自建脚本启动 2种关闭数据库方法 mysqladmin -uroot -p密码 shutdown #优雅关闭/e ...

随机推荐

  1. TF-IDF定义及实现

    TF-IDF定义及实现 定义 ​ TF-IDF的英文全称是:Term Frequency - Inverse Document Frequency,中文名称词频-逆文档频率,常用于文本挖掘,资讯检索等 ...

  2. 深入理解 slab cache 内存分配全链路实现

    本文源码部分基于内核 5.4 版本讨论 在经过上篇文章 <从内核源码看 slab 内存池的创建初始化流程> 的介绍之后,我们最终得到下面这幅 slab cache 的完整架构图: 本文笔者 ...

  3. Prism Sample 1

    这个样例版本上已经过时了,但与8.1版本仍然兼容. 在本版本中,指定启动项: App.xaml.cs: protected override void OnStartup(StartupEventAr ...

  4. ai问答:使用vite如何配置多入口页面

    Vite 是一个 web 开发构建工具,它可以用于开发单页应用和多页应用.要在 Vite 中配置多入口,可以: 在 vite.config.js 中定义多个 entry 入口: export defa ...

  5. Unity中实现字段/枚举编辑器中显示中文(中文枚举、中文标签)

    在unity开发编辑器相关经常会碰到定义的字段显示在Inspector是中文,枚举也经常碰到显示的是字段定义时候的英文,程序还好,但是如果编辑器交给策划编辑,策划的英文水平不可保证,会很头大,所以还是 ...

  6. 2023-04-08:社交网络中的最优邀请策略探究。本文以小红准备开宴会为例,提出一种基于贪心算法和二分查找的解决方案,帮助读者在保证愉悦值不低于k的前提下,最小化宴会的阶层差距。

    2023-04-08:小红有n个朋友, 她准备开个宴会,邀请一些朋友, i号朋友的愉悦值为a[i],财富值为b[i], 如果两个朋友同时参加宴会,这两个朋友之间的隔阂是其财富值差值的绝对值, 宴会的隔 ...

  7. 2022-06-29:x = { a, b, c, d }, y = { e, f, g, h }, x、y两个小数组长度都是4。 如果有: a + e = b + f = c + g = d + h

    2022-06-29:x = { a, b, c, d }, y = { e, f, g, h }, x.y两个小数组长度都是4. 如果有: a + e = b + f = c + g = d + h ...

  8. 2022-05-04:比如,str = “ayxbx“, 有以下4种切法 : a | yxbx、ay | xbx、ayx | bx、ayxb | x, 其中第1、3、4种切法符合:x和y的个数,至少在

    2022-05-04:比如,str = "ayxbx", 有以下4种切法 : a | yxbx.ay | xbx.ayx | bx.ayxb | x, 其中第1.3.4种切法符合: ...

  9. 2021-12-30:分裂问题。 一个数n,可以分裂成一个数组[n/2, n%2, n/2], 这个数组中哪个数不是1或者0,就继续分裂下去。 比如 n = 5,一开始分裂成[2, 1, 2], [2

    2021-12-30:分裂问题. 一个数n,可以分裂成一个数组[n/2, n%2, n/2], 这个数组中哪个数不是1或者0,就继续分裂下去. 比如 n = 5,一开始分裂成[2, 1, 2], [2 ...

  10. flutter填坑之旅(有状态组件StatefulWidget)

    今天我们来看看flutter的StatefulWidget(有状态组件),最常用就是app 主页的底部导航栏的应用 效果图 首页 关于 我的 statefull-widget-learn .dart ...