MySQL WHERE 子句

昨天介绍了 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”的数据)。

MySQL WHERE 子句_第1张图片

实例02

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

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

MySQL WHERE 子句_第2张图片

实例03

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

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

MySQL WHERE 子句_第3张图片

实例04

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

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

MySQL WHERE 子句_第4张图片

实例05

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

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

MySQL WHERE 子句_第5张图片

实例06

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

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

MySQL WHERE 子句_第6张图片

实例07

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

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

MySQL WHERE 子句_第7张图片

实例08

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

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

MySQL WHERE 子句_第8张图片

实例09

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

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

MySQL WHERE 子句_第9张图片

实例10

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

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

MySQL WHERE 子句_第10张图片

实例11

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

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

MySQL WHERE 子句_第11张图片

实例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”的数据)。

MySQL WHERE 子句_第12张图片

实例13

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

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

MySQL WHERE 子句_第13张图片

实例14

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

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

MySQL WHERE 子句_第14张图片

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

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

你可能感兴趣的:(mysql,数据库)