【SQL】未订购的客户

devtools/2024/10/9 1:17:02/

目录

语法

需求

示例

分析

代码


语法

SELECT columns  
FROM table1  
LEFT JOIN table2  
ON table1.common_field = table2.common_field;

LEFT JOIN(或称为左外连接)是SQL中的一种连接类型,它用于从两个或多个表中基于连接条件返回左表(LEFT JOIN语句左侧的表)的所有记录,以及右表中满足连接条件的记录。如果左表中的某行在右表中没有匹配行,则结果中该行的右表部分将包含NULL。

  • table1 是左表,即你希望从中获取所有记录的表。
  • table2 是右表,即你希望根据连接条件从左表中获取匹配记录的表。
  • common_field 是两个表中用于连接的共同字段。

使用LEFT JOIN时,如果右表(departments在上述示例中)有多行与左表(employees)中的某一行相匹配,结果中将包括左表的这一行与右表中所有匹配行的组合。这可能导致结果集中有多行具有相同的左表数据但不同的右表数据。

如果查询目的是获取右表中的所有记录,并且当左表中没有匹配项时,这些记录也应被包括在内,则应该使用RIGHT JOIN。然而,由于SQL标准的可移植性考虑,通常建议通过改变表的顺序和使用LEFT JOIN来达到相同的目的,因为并非所有数据库系统都支持RIGHT JOIN。在某些情况下,当两个表都没有完全匹配的记录时,你可能想要使用FULL OUTER JOIN,但这也不是所有数据库系统都支持的。

SELECT name

FROM customers

WHERE age > 30; 

WHERE子句是一个非常重要的组成部分,它用于指定筛选数据的条件,从而限制查询结果集仅包含满足条件的行。WHERE子句允许使用各种条件表达式,包括比较运算符(如=><<>等)、逻辑运算符(如ANDORNOT)以及特殊函数(如LIKEINBETWEEN等),以实现复杂的筛选逻辑。WHERE子句的使用非常灵活,可以基于单个字段或多个字段的组合来设置筛选条件。此外,还可以结合子查询来实现更高级的筛选逻辑。通过精确地指定筛选条件,WHERE子句有助于减少数据库需要处理的数据量,从而提高查询效率。

  • 在使用WHERE子句时,需要确保条件表达式的正确性,以避免查询结果不符合预期。
  • 当使用多个条件进行筛选时,要注意逻辑运算符的优先级,必要时可以使用括号来明确表达式的执行顺序。
  • 对于大型数据库表,合理的索引设计可以显著提高WHERE子句的执行效率。

需求

Customers 表:

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| name        | varchar |
+-------------+---------+
在 SQL 中,id 是该表的主键。
该表的每一行都表示客户的 ID 和名称。

Orders 表:

+-------------+------+
| Column Name | Type |
+-------------+------+
| id          | int  |
| customerId  | int  |
+-------------+------+
在 SQL 中,id 是该表的主键。
customerId 是 Customers 表中 ID 的外键( Pandas 中的连接键)。
该表的每一行都表示订单的 ID 和订购该订单的客户的 ID。

找出所有从不点任何东西的顾客。

以 任意顺序 返回结果表。

结果格式如下所示。

示例

输入:
Customers table:
+----+-------+
| id | name  |
+----+-------+
| 1  | Joe   |
| 2  | Henry |
| 3  | Sam   |
| 4  | Max   |
+----+-------+
Orders table:
+----+------------+
| id | customerId |
+----+------------+
| 1  | 3          |
| 2  | 1          |
+----+------------+
输出:
+-----------+
| Customers |
+-----------+
| Henry     |
| Max       |
+-----------+

分析

找出所有从不点任何东西的顾客。

判断客户是否曾经下过订单的条件是:如果一个客户 ID 在 orders 表中不存在,这就意味着他们从未下过订单。

基于共同的客户 ID(在 customers 表中的 id 列和 orders 表中的 customerId 列),将表 customers 与表 orders 进行连接。

left join Orders on Customers.Id = Orders.CustomerId

左连接之后选择 customerId 为 null 的记录,我们可以确定哪些客户没有下过订单。

where Orders.CustomerId is null

代码

select name as 'Customers'
from Customers
left join Orders on Customers.Id = Orders.CustomerId
where Orders.CustomerId is null


http://www.ppmy.cn/devtools/120436.html

相关文章

影响 Linux、Unix 系统的 CUPS 漏洞可导致 RCE

在经过大量炒作和第三方过早泄露信息之后&#xff0c;安全研究员 Simone Margaritelli 公布了有关通用 UNIX 打印系统 (CUPS) 中的四个零日漏洞的详细信息。 这些漏洞可被远程、未经身份验证的攻击者滥用&#xff0c;在易受攻击的 Linux 和类 Unix 系统上实现代码执行。 CUPS…

Python绘图库----turtle(海龟)

Python库 python程序的集合&#xff0c;这些程序都有不同的功能。Python库就相当于一个工具箱&#xff0c;里面有各种工具&#xff0c;工具的功能都有所不同。 Python绘图库 Python绘图库----turtle&#xff08;海龟&#xff09;&#xff0c;turtle 具有绘画功能&#xff0c…

MacOS配置python环境

下载 Python 前往网站下载对应芯片和python版本的 installer。 配置环境变量 sudo vim ~/.bash_profile添加一下内容&#xff0c;注意修改文件名。 export PATH"/Library/Frameworks/Python.framework/Versions/3.11/bin:${PATH}" alias python"/Library/Fr…

Java Web应用升级故障案例解析

在一次Java Web应用程序的优化升级过程中&#xff0c;从Tomcat 7.0.109版本升级至8.5.93版本后&#xff0c;尽管在预发布环境中验证无误&#xff0c;但在灰度环境中却发现了一个令人困惑的问题&#xff1a;新日志记录神秘“失踪”。本文深入探讨了这一问题的排查与解决过程&…

Android常用C++特性之std::unique

声明&#xff1a;本文内容生成自ChatGPT&#xff0c;目的是为方便大家了解学习作为引用到作者的其他文章中。 std::unique 是 C 标准库中的一个算法函数&#xff0c;用于移除相邻的重复元素&#xff0c;使每个相邻的元素在容器中保持唯一。它不会真正移除元素&#xff0c;而是通…

计算机网络:计算机网络概述:网络、互联网与因特网的区别

文章目录 网络、互联网与因特网的区别网络分类 互联网因特网基于 ISP 的多层次结构的互连网络因特网的标准化工作因特网管理机构因特网的组成 网络、互联网与因特网的区别 若干节点和链路互连形成网络&#xff0c;若干网络通过路由器互连形成互联网 互联网是全球范围内的网络…

微信小程序攻略:如何验证Token是否即将失效并自动刷新

在微信小程序的开发中&#xff0c;我们通常使用Token来管理用户的登录状态。Token具有一定的有效期&#xff0c;一旦失效&#xff0c;用户将需要重新登录。为了提升用户体验&#xff0c;我们可以在Token快要失效时提前刷新Token&#xff0c;避免用户在操作过程中突然退出。以下…

中心节点服务,远程集中管理,降低边缘设备管理成本的智慧园区开源了。

智慧园区场景视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。 它的愿景是最底层打通各大芯片厂商相互间的壁垒&#xff0c;省去繁琐重复的适配流程&#xff0c;实现芯片、算法、应用的全流程组合&#xff0c;从而大大减少企业级应用约95%的开发成本。充分利用现…