数据的连接与关联查询

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. PHPCMSV9 单文件上传功能代码

    后台有"多文件上传"功能,但是对于有些情况,我们只需要上传一个文件,而使用多文件上传功能上传一个文件,而调用时调用一个文件太麻烦了. 所以我就自己动手,参考其他字段类型的网站,研究 ...

  2. 22-source-map

    const { resolve } = require('path') const htmlWebpackPlugins = require('html-webpack-plugin') module ...

  3. 去中心化金融-Lec2

    Finance Finance is the process that involves the creation, management, and investment of money and f ...

  4. 前端 引用svg图片,支持动态切换颜色

    当我们添加一张svg图片显示时,react提示找不到文件. 我们可以在全局文件global.d.ts内,添加图片类型的声明: 详见<TypeScript 引用资源文件后提示找不到的错误处理方案& ...

  5. 打开conda环境报错:UnicodeDecodeError: ‘gbk‘ codec can‘t decode byte 0x9a in position 317: illegal multibyt

    解决打开conda环境报错:UnicodeDecodeError: 'gbk' codec can't decode byte 0x9a in position 317: illegal multib ...

  6. ReactHub:我用 ChatGPT 搞了一个 React 的资源导航网站,谁有我用心啊!

    大家好,我是DOM哥. 图谱年年有,今年我来盘! 之前已经盘完了 Vue 的技术图谱,今天来盘 React 的. 我用 ChatGPT 开发了一个 React 的资源导航网站. 不管你是资深 Reac ...

  7. 在chatGPT的帮助下成功从Rancher中删除无效的集群

    只要你坚持,不放弃,问题总有解决的一天! 与chatgpt进行了几次沟通,成功解决历史遗留问题,成功从rancher中删除了无效的集群 chatGPT回答1 如果您在 Rancher UI 中无法删除 ...

  8. 2023-03-30:用Go语言改写FFmpeg示例decode_audio.c,实现高效音频解码。

    2023-03-30:用Go语言改写FFmpeg示例decode_audio.c,实现高效音频解码. 答案2023-03-30: 这个程序的主要功能是将 MP2 音频文件解码为 PCM 格式,并输出到 ...

  9. 2022-04-17:给定一个数组arr,其中的值有可能正、负、0, 给定一个正数k。 返回累加和>=k的所有子数组中,最短的子数组长度。 来自字节跳动。力扣862。

    2022-04-17:给定一个数组arr,其中的值有可能正.负.0, 给定一个正数k. 返回累加和>=k的所有子数组中,最短的子数组长度. 来自字节跳动.力扣862. 答案2022-04-17: ...

  10. Selenium - 浏览器配置(1) - 忽略证书错误提示

    Selenium - 浏览器配置 忽略证书错误提示 有时候我们访问一些地址,会提示证书私密连接告警信息如下: 如果我们每次要点击高级来忽略私密连接,那就很麻烦: 在谷歌浏览器可以增加忽略证书错误问题, ...