从零学SQL 07 数据过滤

在数据库查询中,你很少需要检索表中的所有行。更常见的情况是根据特定的业务逻辑提取数据子集。本文将通过 MySQL 官方提供的 world 示例数据库,带你掌握条件过滤子句 WHERE 的用法。


文章目录

    • [一、 单条件过滤](#一、 单条件过滤)
      • [1.1 WHERE 子句](#1.1 WHERE 子句)
      • [1.2 检查范围:BETWEEN ... AND](#1.2 检查范围:BETWEEN ... AND)
      • [1.3 集合筛选:IN 运算符](#1.3 集合筛选:IN 运算符)
      • [1.4 空值的处理:IS NULL / <=>](#1.4 空值的处理:IS NULL / <=>)
    • [二、 多条件过滤:逻辑组合](#二、 多条件过滤:逻辑组合)
      • [2.1 AND 与 OR](#2.1 AND 与 OR)
      • [2.2 优先级的陷阱](#2.2 优先级的陷阱)
      • [2.3 NOT 运算符](#2.3 NOT 运算符)
        • [2.3.1 NOT IN](#2.3.1 NOT IN)
        • [2.3.2 NOT NULL](#2.3.2 NOT NULL)

一、 单条件过滤

过滤条件放在 WHERE 子句里,紧跟在 FROM 子句之后,如果有ORDER BY子句,那么需要放WHERE 子句之后。

完整的语法是:SELECT 查询列 FROM 表名 WHERE 过滤条件 ORDER BY 排序列;

1.1 WHERE 子句

city 表中,如果我们想找人口数刚好等于 1,000,000 的城市:

sql 复制代码
SELECT Name, Population 
FROM city 
WHERE Population = 1000000;

过滤条件通常是一个表达式,除了等号,SQL 还支持多种运算符:

操作符 描述
= 相等
<> 不相等
!= 不相等
< 小于
<= 小于或等于
> 大于
>= 大于或等于

1.2 检查范围:BETWEEN ... AND

如果你想查找人口在 100 万到 200 万之间的城市,BETWEEN...AND... 是更好的选择(包含上下边界):

sql 复制代码
SELECT Name, Population 
FROM city 
WHERE Population BETWEEN 1000000 AND 2000000;

1.3 集合筛选:IN 运算符

当你要匹配多个特定值时,可以用IN 运算符进行检测,值放在括号中,以逗号分隔。

例如,查找中国 (CHN)、美国 (USA) 的城市:

sql 复制代码
SELECT Name, CountryCode 
FROM city 
WHERE CountryCode IN ('CHN', 'USA');

1.4 空值的处理:IS NULL / <=>

在MySQL中,NULL 代表未知或缺失,它不等于 0,也不等于空字符串。

country 表中,我想查找某些国家的独立年份(IndepYear)缺失,需要使用 IS NULL来过滤。同理,如果要查非空的记录则使用IS NOT NULL

sql 复制代码
SELECT Name 
FROM country 
WHERE IndepYear IS NULL;

避坑: 永远不要写 WHERE IndepYear = NULL,这在 SQL 逻辑中永远返回 False。

扩展:

MySQL的 <=> 是一个特殊的NULL 安全相等运算符(也叫 "空值安全等号"),作用是:既能比较普通值是否相等,同时也会将 NULL 值视为相等,使用的概率较低。


二、 多条件过滤:逻辑组合

当业务逻辑变复杂时,我们需要用逻辑运算符将多个条件串联起来。

2.1 AND 与 OR

  • AND: 所有条件必须同时满足。
  • OR: 只要满足其中一个条件即可。
sql 复制代码
-- 查找人口超过 500 万,且位于中国的城市
SELECT Name, Population 
FROM city 
WHERE Population > 5000000 AND CountryCode = 'CHN';

2.2 优先级的陷阱

AND 的优先级高于 OR。如果你混合使用它们,务必使用**圆括号 ()

错误示例:查找中国或美国人口超 500 万的城市:

sql 复制代码
SELECT * FROM city
WHERE CountryCode = 'CHN' OR CountryCode = 'USA' AND Population > 5000000;

正确写法:

sql 复制代码
SELECT * FROM city
WHERE (CountryCode = 'CHN' OR CountryCode = 'USA') AND Population > 5000000;、

2.3 NOT 运算符

NOT 用来否定其后的任何条件,它通常与 INNULL结合。

2.3.1 NOT IN

查找除了中国和美国以外的所有国家:

sql 复制代码
SELECT * 
FROM city 
WHERE CountryCode NOT IN ('CHN', 'USA');
2.3.2 NOT NULL

查找独立年份不为空的国家:

sql 复制代码
SELECT *
FROM country 
WHERE IndepYear IS NOT NULL;

掌握过滤条件是写出高效 SQL 的第一步,下一节我们将一起学习SQL条件过滤中的:通配符过滤(模糊匹配)

相关推荐
2301_7838486510 分钟前
优化文本分类中堆叠模型的网格搜索性能:避免训练卡顿的实战指南
jvm·数据库·python
拾贰_C22 分钟前
【Ubuntu | 公共工作站 | mysql 】 MySQL残留物残留数据
linux·mysql·ubuntu
TE-茶叶蛋32 分钟前
DBeaver 的Explain 执行计划,分析sql的性能
数据库·sql
CLX05051 小时前
如何安装Oracle 12c Cloud Control_OMS服务端组件与Agent部署
jvm·数据库·python
m0_617493941 小时前
PySide6 网络请求深度实测:从基础 API 调用到数据解析实战指南
数据库
知识汲取者2 小时前
每日一篇高频面试题系列之【MySQL 锁】
数据库·mysql
老纪2 小时前
SQL中如何查找特定的空值行:WHERE IS NULL深度解析
jvm·数据库·python
麦聪聊数据2 小时前
数据 API 平台选型:深度解读数据服务的四大关键技术与架构底座
数据库·sql
IT研究所2 小时前
AI 时代下的知识管理:从 Claude 的“复盘”能力看生成式 AI价值
大数据·运维·数据库·人工智能·科技·低代码·自然语言处理
2301_781571422 小时前
mysql数据库响应缓慢如何排查_使用EXPLAIN分析执行计划
jvm·数据库·python