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)。

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

相关推荐
我叫唧唧波6 小时前
Python+AI 全栈学习笔记
人工智能·python·学习
不会就选b6 小时前
MySQL之视图
数据库·mysql
城北徐宫6 小时前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
>no problem<7 小时前
基于cola5.0的基础设施层的多数据库切换方案思路
数据库·spring boot·mybatisplus·cola5.0·数据库迁移适配
OceanBase数据库官方博客7 小时前
OceanBase 赋能央国企:从发电到用电的全链路业务承载
数据库·oceanbase
三品吉他手会点灯8 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
疯狂打码的少年8 小时前
中断处理过程与中断优先级
笔记
瀚高PG实验室8 小时前
pgsql-ogr-fdw
数据库·postgresql·瀚高数据库·highgo
IvorySQL8 小时前
PostgreSQL 技术日报 (6月5日)|PG19 Beta1 上线,PGConf.PL 2026开启征稿
数据库·postgresql·区块链
likerhood8 小时前
WSL 下安装 Miniconda 笔记
笔记·wsl