MySQL WHERE 子句

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 【1月更文挑战第2天】MySQL 使用讲解 第02期

昨天介绍了 MySQL 数据库使用 SELECT 语句来查询数据,同时也简单提到了MySQL WHERE 子句,今天详细讲解下。

语法

我们知道从 MySQL 表中使用 SELECT 语句来读取数据,如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中,WHERE 子句用于在 MySQL 中过滤查询结果,只返回满足特定条件的行。

老规矩,先介绍一下语法。以下是 SQL SELECT 语句使用 WHERE 子句从数据表中读取数据的通用语法:

SELECT column1, column2, ...
FROM table_name
WHERE condition;

参数说明

  • column1, column2, ... 是你要选择的列的名称,如果使用 * 表示选择所有列。
  • table_name 是你要从中查询数据的表的名称。
  • WHERE condition 是用于指定过滤条件的子句。

更多说明

  • 查询语句中你可以使用一个或者多个表,表之间使用逗号, 分割,并使用WHERE语句来设定查询条件。
  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以使用 AND 或者 OR 指定一个或多个条件。
  • WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。
  • WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。

参数介绍完成,再介绍下操作符。以下为操作符列表,可用于 WHERE 子句中(假定 A 为 5, B 为 10)。

操作符 描述 实例
= 等号,检测两个值是否相等,如果相等返回true (A = B) 返回false
<>, != 不等于,检测两个值是否相等,如果不相等返回true (A != B) 返回 true
> 大于号,检测左边的值是否大于右边的值, 如果左边的值大于右边的值返回true (A > B) 返回false
< 小于号,检测左边的值是否小于右边的值, 如果左边的值小于右边的值返回true (A < B) 返回 true
>= 大于等于号,检测左边的值是否大于或等于右边的值, 如果左边的值大于或等于右边的值返回true (A >= B) 返回false
<= 小于等于号,检测左边的值是否小于或等于右边的值, 如果左边的值小于或等于右边的值返回true (A <= B) 返回 true

为了让同学们更好的理解MySQL WHERE 子句的使用,接下来通过一些实例来详细介绍下。

实例01

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE page_id = 'page1001';

-- 解释:等于条件(查询页面ID等于“page1001”的数据)。

在这里插入图片描述

实例02

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE page_id != 'page1001';

-- 解释:不等于条件(查询页面ID不等于“page1001”的数据)。

在这里插入图片描述

实例03

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE id > 5;

-- 解释:大于条件(查询ID大于“5”的数据)。

在这里插入图片描述

实例04

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE id < 5;

-- 解释:小于条件(查询ID小于“5”的数据)。

在这里插入图片描述

实例05

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE id >= 5;

-- 解释:大于等于条件(查询ID大于等于“5”的数据)。

在这里插入图片描述

实例06

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE id <= 5;

-- 解释:小于等于条件(查询ID小于等于“5”的数据)。

在这里插入图片描述

实例07

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE page_state = 'true' AND create_date > '2021-01-01'; 

-- 解释:组合条件(AND)(查询页面状态为“true”,且创建时间大于“2021-01-01”的数据)。

在这里插入图片描述

实例08

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE id = 5 OR create_date > '2021-01-01'; 

-- 解释:组合条件(OR)(查询ID等于“5”,或创建时间大于“2021-01-01”的数据)。

在这里插入图片描述

实例09

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE page_name LIKE '%表格%';

-- 解释:模糊匹配条件(LIKE)(查询页面名称中包含“表格”的数据)。

在这里插入图片描述

实例10

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE page_id IN ('page1003','page1009');

-- 解释:IN 条件(查询表格ID等于“page1003”或“page1009”的数据)。

在这里插入图片描述

实例11

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE NOT page_id = 'page1003';

-- 解释:NOT 条件(查询表格ID不等于“page1003”的数据)。

在这里插入图片描述

实例12

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE create_date BETWEEN '2021-01-01' AND '2021-02-01'; 

-- 解释:BETWEEN 条件(查询创建时间在“2021-01-01”至“2021-02-01”的数据)。

在这里插入图片描述

实例13

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE remarks IS NULL;

-- 解释:IS NULL 条件(查询备注为“NULL”的数据)。

在这里插入图片描述

实例14

-- 2024.01.17 查询页面清单
SELECT * FROM nm_list_page WHERE remarks IS NOT NULL;

-- 解释:IS NOT NULL 条件(查询备注不为“NULL”的数据)。

在这里插入图片描述

通过以上实例,我们可以看出如果想在 MySQL 数据表中读取指定的数据,WHERE 子句是非常有用的。并且,使用主键来作为 WHERE 子句的条件查询是非常快速的。如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。

以上内容即为 MySQL 数据库使用 WHERE 子句来查询数据的简单讲解,下期再见。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
28天前
|
关系型数据库 MySQL 数据库
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
|
2月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL LIKE 子句
总结 vue3 的一些知识点:MySQL LIKE 子句
|
5月前
|
SQL 关系型数据库 MySQL
MySQL LIKE 子句
MySQL LIKE 子句
|
5月前
|
SQL 关系型数据库 MySQL
MySQL WHERE 子句
MySQL WHERE 子句
|
21天前
|
关系型数据库 MySQL Serverless
MySQL中的having和where的区别
总之,`WHERE` 用于过滤原始数据,`HAVING` 用于在 `GROUP BY` 后对聚合数据进行筛选。它们分别适用于不同的查询需求。
14 0
|
3月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL LIKE 子句
总结 vue3 的一些知识点:MySQL LIKE 子句
|
4月前
|
关系型数据库 MySQL Unix
MySQL LIKE 子句
【1月更文挑战第5天】MySQL 使用讲解 第05期
|
4月前
|
SQL 关系型数据库 MySQL
【MySQL进阶之路丨第九篇】一文带你精通MySQL子句
【MySQL进阶之路丨第九篇】一文带你精通MySQL子句
22 0
|
5月前
|
SQL 前端开发 关系型数据库
MYSQL基础知识之【LIKE子句的使用 ,NULL值的处理,空值的处理】
MYSQL基础知识之【LIKE子句的使用 ,NULL值的处理,空值的处理】
60 0
|
5月前
|
SQL 前端开发 关系型数据库
MYSQL where 子句
MYSQL where 子句
28 0