MySQL 查询进阶(二):行筛选与条件查询

上一篇我们以学生表为例掌握了 SQL 查询的列选择、算数运算和别名使用,本文将继续聚焦 "行选择"------ 如何通过条件筛选出符合要求的学生数据行,包括比较条件、逻辑条件、模糊匹配等核心技巧。


目录

一、行选择的核心语法

二、基础比较条件

三、高级比较条件

[1. BETWEEN AND:范围筛选](#1. BETWEEN AND:范围筛选)

[2. IN:多值匹配](#2. IN:多值匹配)

[3. LIKE:模糊匹配](#3. LIKE:模糊匹配)

[4. NULL 条件:空值判断](#4. NULL 条件:空值判断)

四、逻辑条件:多条件组合

总结


一、行选择的核心语法

行筛选依赖WHERE子句,紧跟在FROM之后,语法如下:

sql 复制代码
SELECT 投影列 FROM 表名 WHERE 筛选条件;

投影列即需要查询的列,筛选条件是行筛选的核心,支持多种条件类型(以下均以student学生表为例)。

二、基础比较条件

比较条件用于判断列值与指定值的大小 / 相等关系,常用运算符:=、>、>=、<、<=、!=(<>)

示例 1:查询数学成绩≥90 分的学生姓名和数学成绩

sql 复制代码
SELECT st_name, math_score FROM student WHERE math_score >= 90;

示例 2:查询语文成绩≠60 分的学生姓名和语文成绩

sql 复制代码
SELECT st_name, chinese_score FROM student WHERE chinese_score != 60;
-- 等价写法
SELECT st_name, chinese_score FROM student WHERE chinese_score <> 60;

三、高级比较条件

1. BETWEEN AND:范围筛选

用于查询列值在 "最小值 - 最大值" 区间内的数据(包含边界值),比 >= + <= 更简洁。

语法

sql 复制代码
WHERE 列名 BETWEEN 最小值 AND 最大值;
-- 反向筛选(不在区间内)
WHERE 列名 NOT BETWEEN 最小值 AND 最大值;

示例:查询数学成绩在 80-95 分之间的学生姓名和数学成绩

sql 复制代码
SELECT st_name, math_score FROM student WHERE math_score BETWEEN 80 AND 95;

2. IN:多值匹配

判断列值是否在指定的多个值中,替代多个OR条件,简化语句。

语法

sql 复制代码
WHERE 列名 IN (值1, 值2, 值3......);
-- 反向筛选(不在指定值中)
WHERE 列名 NOT IN (值1, 值2, 值3......);

示例:查询班级 ID 为 1、3、5 的学生姓名和班级 ID

sql 复制代码
SELECT st_name, class_id FROM student WHERE class_id IN (1,3,5);

3. LIKE:模糊匹配

用于字符串的模糊查询(如按姓名筛选),搭配通配符使用:

  • %:匹配 0 个或多个任意字符;
  • _:匹配 1 个任意字符。

语法

sql 复制代码
WHERE 列名 LIKE '匹配规则';

示例 1:查询姓名以 "张" 开头的学生姓名

sql 复制代码
SELECT st_name FROM student WHERE st_name LIKE '张%';

示例 2:查询姓名第二个字是 "小" 的学生姓名

sql 复制代码
SELECT st_name FROM student WHERE st_name LIKE '_小%';

4. NULL 条件:空值判断

判断列值是否为空(如学生的家庭地址是否填写),必须使用IS NULL/IS NOT NULL ,不能用=!=

示例 1:查询未填写家庭地址的学生姓名和地址

sql 复制代码
SELECT st_name, address FROM student WHERE address IS NULL;

示例 2:查询已填写家庭地址的学生姓名和地址

sql 复制代码
SELECT st_name, address FROM student WHERE address IS NOT NULL;

四、逻辑条件:多条件组合

当需要多个筛选条件同时生效时,使用逻辑运算符组合:

  • AND:多个条件同时满足
  • OR:多个条件满足其一
  • NOT:取反条件。

示例 1:数学成绩 = 100 分且姓名含 "李" 的学生(AND)

sql 复制代码
SELECT st_name, math_score FROM student WHERE math_score = 100 AND st_name LIKE "%李%";

示例 2:数学成绩≥90 分或语文成绩≥90 分的学生(OR)

sql 复制代码
SELECT st_name, math_score, chinese_score FROM student WHERE math_score >= 90 OR chinese_score >= 90;

示例 3:姓名不含 "王" 的学生(NOT)

sql 复制代码
SELECT st_name FROM student WHERE st_name NOT LIKE "%王%";

总结

  1. 行筛选依赖WHERE子句,核心是灵活使用各类条件;
  2. 模糊查询用LIKE+ 通配符(%/_),空值判断用IS NULL/IS NOT NULL
  3. 多条件组合用AND/OR/NOT,注意条件的优先级(AND高于OR)。

希望这篇文章对你有帮助,如果你有任何问题或建议,欢迎在评论区留言。谢谢阅读(求攒攒 收藏 关注)!

相关推荐
2401_831824962 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf21 分钟前
Python日志记录(Logging)最佳实践
jvm·数据库·python
twc82921 分钟前
大模型生成 QA Pairs 提升 RAG 应用测试效率的实践
服务器·数据库·人工智能·windows·rag·大模型测试
@我漫长的孤独流浪21 分钟前
Python编程核心知识点速览
开发语言·数据库·python
2401_8512729923 分钟前
实战:用Python分析某电商销售数据
jvm·数据库·python
枕布响丸辣29 分钟前
MySQL 从入门到精通:完整操作手册与实战指南
数据库·mysql
电商API&Tina41 分钟前
【电商API接口】开发者一站式电商API接入说明
大数据·数据库·人工智能·云计算·json
2401_8579182943 分钟前
用Python和Twilio构建短信通知系统
jvm·数据库·python
solicitous43 分钟前
遇到一个口头机遇
学习·生活
樹JUMP1 小时前
使用Docker容器化你的Python应用
jvm·数据库·python