昨天介绍了 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 子句来查询数据的简单讲解,下期再见。