MySQL WHERE 子句

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 【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 子句来查询数据的简单讲解,下期再见。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
关系型数据库 MySQL 数据库
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
137 0
|
6月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL LIKE 子句
总结 vue3 的一些知识点:MySQL LIKE 子句
|
1月前
|
SQL 关系型数据库 MySQL
MySQL中的 where 1=1会不会影响性能?看完官方文档就悟了!
本文探讨了在Mybatis中使用`where 1=1`进行动态SQL拼接是否会影响性能。通过MySQL官方资料和实际测试表明,`where 1=1`在MySQL 5.7及以上版本中会被优化器优化,因此对性能影响不大。文中详细对比了`where 1=1`与`&lt;where&gt;`标签的使用方法,并建议根据MySQL版本和团队需求选择合适的方式。最后,推荐查找官方资料以确保技术路线正确。
39 4
|
3月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 `HAVING` 子句
【8月更文挑战第12天】
141 1
在 MySQL 中使用 `HAVING` 子句
|
3月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 `GROUP BY` 子句
【8月更文挑战第12天】
87 1
|
5月前
|
SQL 关系型数据库 MySQL
蓝易云 - Mysql join加多条件与where的区别
总的来说,JOIN和WHERE都是SQL查询的重要部分,但它们用于处理不同的问题:JOIN用于连接表,而WHERE用于过滤结果。
32 2
|
5月前
|
SQL 关系型数据库 MySQL
MySQL中的where和having的区别
MySQL中的where和having的区别
58 2
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
【MySQL】DQL-分组查询-语法&where与having的区别&注意事项&可cv例题语句
|
5月前
|
关系型数据库 MySQL SQL
MySQL的 where 1=1会不会影响性能?
在MySQL动态SQL中,使用`where 1=1`主要目的是简化动态条件的拼接,有人担心这可能影响性能。然而,通过官方文档和实际测试发现,由于MySQL的Constant-Folding Optimization(常量折叠优化),`where 1=1`在大多数情况下会被优化掉,对性能影响微乎其微。MyBatis提供了`&lt;where&gt;`标签,能更有效地处理动态SQL,避免多余的`AND`或`OR`。当MySQL版本大于等于5.7时,两者性能差异不大,选择哪种方式可根据团队规范和个人喜好。而在旧版本中,如果使用MyBatis,推荐使用`&lt;where&gt;`标签。
130 0
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】where和having的区别
【MySQL】where和having的区别