news 2026/6/23 0:37:11

SQL联查案例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL联查案例

SQL 联查(Join)是将来自两个或多个表的数据结合在一起的操作。以下是一些常用的 SQL 联查示例,包括内联接、左联接、右联接和全外联接。

示例数据库表和数据

1. Customers (客户表)
CustomerIDNameCity
1AliceNew York
2BobLos Angeles
3CharlieChicago
4DavidSan Francisco
5EveMiami
2. Orders (订单表)
OrderIDCustomerIDOrderDateAmount
10112025-01-15150.00
10212025-02-20200.00
10322025-01-25300.00
10432025-03-05450.00
10542025-04-10500.00

查询和输出效果

1. 内联接 (INNER JOIN)

查询所有下过订单的客户及其订单信息:

SELECT Customers.CustomerID, Customers.Name, Orders.OrderID, Orders.OrderDate, Orders.Amount FROM Customers INNER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

输出结果:

CustomerIDNameOrderIDOrderDateAmount
1Alice1012025-01-15150.00
1Alice1022025-02-20200.00
2Bob1032025-01-25300.00
3Charlie1042025-03-05450.00
4David1052025-04-10500.00
2. 左联接 (LEFT JOIN)

查询所有客户及其订单信息,包括没有下过订单的客户:

SELECT Customers.CustomerID, Customers.Name, Orders.OrderID, Orders.OrderDate, Orders.Amount FROM Customers LEFT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

输出结果:

CustomerIDNameOrderIDOrderDateAmount
1Alice1012025-01-15150.00
1Alice1022025-02-20200.00
2Bob1032025-01-25300.00
3Charlie1042025-03-05450.00
4David1052025-04-10500.00
5EveNULLNULLNULL
3. 右联接 (RIGHT JOIN)

查询所有订单及其客户信息,包括没有客户信息的订单:

SELECT Customers.CustomerID, Customers.Name, Orders.OrderID, Orders.OrderDate, Orders.Amount FROM Customers RIGHT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

输出结果:

CustomerIDNameOrderIDOrderDateAmount
1Alice1012025-01-15150.00
1Alice1022025-02-20200.00
2Bob1032025-01-25300.00
3Charlie1042025-03-05450.00
4David1052025-04-10500.00
4. 全外联接 (FULL OUTER JOIN)

查询所有客户与所有订单的信息,包括没有匹配的客户和订单:

SELECT Customers.CustomerID, Customers.Name, Orders.OrderID, Orders.OrderDate, Orders.Amount FROM Customers FULL OUTER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

输出结果:

CustomerIDNameOrderIDOrderDateAmount
1Alice1012025-01-15150.00
1Alice1022025-02-20200.00
2Bob1032025-01-25300.00
3Charlie1042025-03-05450.00
4David1052025-04-10500.00
5EveNULLNULLNULL
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 7:42:19

minio分片上传

minio分片上传前言分片上传的技术选择实现分片上传第一步自定义客户端初始化分片上传获取一个上传分片的url共前端使用确认每一个分片的上传合并分片文件前言 为什么要选择将一个大文件拆分成许多小文件来上传? 对于许多服务器和应用框架来说,单次HTTP…

作者头像 李华
网站建设 2026/6/23 16:04:14

基于MATLAB实现深度学习图像分类

一、环境配置与数据准备 1.1 环境要求 MATLAB版本:R2021a及以上(需安装Deep Learning Toolbox)GPU支持:推荐NVIDIA CUDA兼容显卡(通过gpuDevice验证) 1.2 数据组织结构 dataset/ ├── train/ │ ├──…

作者头像 李华
网站建设 2026/6/23 16:04:36

9、UNIX/Linux 文件操作全解析

UNIX/Linux 文件操作全解析 1. 文件内容的初步探索 当你尝试使用 cat 命令查看文件内容时,可能会遇到权限问题,例如: $ cat myfile cat: myfile: Permission denied若已知文件存在,我们自然会想知道它的内容。虽然文件本质是字节序列,但我们更关心这些字节代表什么。…

作者头像 李华
网站建设 2026/6/23 6:16:49

企业SRC支付漏洞EDUSRC众测挖掘思路技巧操作分享

0x1 前言这篇文章也是给师傅们分享几个SRC漏洞挖掘中的技巧点,两个企业SRC漏洞案例,支付漏洞中,师傅们碰到都可以进行尝试验证下,要是挖到了,像众测中就是中、高危起步了。赏金的价格还不错,两个案例也写的…

作者头像 李华
网站建设 2026/6/23 17:46:04

webpack输出代码报错到指定文本文件

文章目录 概述代码 概述 在vscode的控制台输出的报错是有限的,多了就看不全了。想要看全部代码报错,就产生了如下方式: 代码 // 在package.json的scripts下,增加以下配置: start2: "set NO_COLOR1 && …

作者头像 李华
网站建设 2026/6/23 17:52:55

自然语言处理容易混淆知识点(二)BERT和BERTopic的区别

BERT和BERTopicBERT(深度学习模型)BERTopic(主题建模工具包)关系类比详细对比1. BERT:基础组件2. BERTopic:完整系统技术架构图关键区别表格实际代码对比**只用 BERT**使用 BERTopic常见混淆点澄清1. 名字为…

作者头像 李华