MySQL 多条件查询

在 MySQL 中,多条件查询通常使用 WHERE 子句来指定多个条件。这些条件可以通过逻辑运算符(如 ANDORNOT)进行组合,以实现复杂的查询需求。以下是一些常见的多条件查询示例:

使用 AND 运算符

AND 运算符用于组合多个条件,并且所有条件都必须为真,才能返回结果。

sql 复制代码
SELECT * FROM employees
WHERE age > 30 AND department = 'Sales';

这条查询语句将返回 employees 表中所有年龄大于 30 且部门为 'Sales' 的记录。

使用 OR 运算符

OR 运算符用于组合多个条件,只要其中一个条件为真,就会返回结果。

sql 复制代码
SELECT * FROM employees
WHERE age > 30 OR department = 'HR';

这条查询语句将返回 employees 表中所有年龄大于 30 或部门为 'HR' 的记录。

使用 ANDOR 组合

你可以将 ANDOR 运算符组合在一起,以创建更复杂的查询条件。需要注意的是,使用括号 () 来明确运算顺序,因为 AND 的优先级高于 OR

sql 复制代码
SELECT * FROM employees
WHERE (age > 30 AND department = 'Sales') OR (age < 25 AND department = 'HR');

这条查询语句将返回 employees 表中所有年龄大于 30 且部门为 'Sales' 的记录,或者所有年龄小于 25 且部门为 'HR' 的记录。

使用 NOT 运算符

NOT 运算符用于否定一个条件。

sql 复制代码
SELECT * FROM employees
WHERE NOT department = 'IT';

这条查询语句将返回 employees 表中所有部门不是 'IT' 的记录。

使用 IN 运算符

IN 运算符用于匹配多个可能的值。

sql 复制代码
SELECT * FROM employees
WHERE department IN ('Sales', 'HR', 'Finance');

这条查询语句将返回 employees 表中所有部门为 'Sales'、'HR' 或 'Finance' 的记录。

使用 BETWEEN 运算符

BETWEEN 运算符用于在一个范围内查找值。

sql 复制代码
SELECT * FROM employees
WHERE age BETWEEN 25 AND 35;

这条查询语句将返回 employees 表中所有年龄在 25 到 35 岁之间的记录(包括 25 和 35)。

使用 LIKE 运算符

LIKE 运算符用于进行模糊匹配。

sql 复制代码
SELECT * FROM employees
WHERE name LIKE 'J%';

这条查询语句将返回 employees 表中所有名字以 'J' 开头的记录。

综合示例

下面是一个综合示例,展示了如何组合多个条件进行查询:

sql 复制代码
SELECT * FROM employees
WHERE (age BETWEEN 25 AND 40) AND (department = 'Sales' OR department = 'HR') AND NOT (name LIKE '%Smith%');

这条查询语句将返回 employees 表中所有年龄在 25 到 40 岁之间,部门为 'Sales' 或 'HR',且名字中不包含 'Smith' 的记录。

通过这些示例,你可以看到 MySQL 的多条件查询是如何通过不同的逻辑运算符进行组合的,从而满足各种复杂的查询需求。

相关推荐
The_Ticker31 分钟前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程
Elastic 中国社区官方博客37 分钟前
Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
企鹅侠客42 分钟前
ETCD调优
数据库·etcd
Json_181790144801 小时前
电商拍立淘按图搜索API接口系列,文档说明参考
前端·数据库
诸神黄昏EX1 小时前
Android 分区相关介绍
android
煎饼小狗1 小时前
Redis五大基本类型——Zset有序集合命令详解(命令用法详解+思维导图详解)
数据库·redis·缓存
永乐春秋1 小时前
WEB-通用漏洞&SQL注入&CTF&二次&堆叠&DNS带外
数据库·sql
打鱼又晒网2 小时前
【MySQL】数据库精细化讲解:内置函数知识穿透与深度学习解析
数据库·mysql
大白要努力!2 小时前
android 使用SQLiteOpenHelper 如何优化数据库的性能
android·数据库·oracle
Estar.Lee2 小时前
时间操作[取当前北京时间]免费API接口教程
android·网络·后端·网络协议·tcp/ip