大厂都这么使用MySQL8进行条件查询(下)

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 大厂都这么使用MySQL8进行条件查询(下)

7 复合条件

借助于逻辑代数中的逻辑运算,SQL 提供了三个逻辑运算符:

7.1 AND 逻辑与运算符

只有当两边的条件都为真时,结果才为真,返回数据;否则,不返回数据。

以下示例使用 AND 运算符查找性别为“女”,并且月薪超过 10000 的员工:

SELECT emp_name, sex, salary
  FROM employee
 WHERE sex = '女'
   AND salary > 10000;
emp_name|sex|salary  |
--------|---|--------|
孙尚香   |女 |12000.00|
“孙尚香”是女性员工,并且月薪为 12000。
  • OR,逻辑或运算符。只要有一个条件为真,结果就为真,返回数据;否则,不返回数据。
  • NOT,逻辑非运算符。用于将判断结果取反,真变为假,假变为真;空值取反后仍然为空值。


7.2 OR 运算符

使用 OR 运算符查找姓名为“刘备”、“关羽”或者“张飞”的员工:

SELECT emp_name, sex, salary
  FROM employee
 WHERE emp_name = '刘备'
    OR emp_name = '关羽'
    OR emp_name = '张飞';

该查询的结果与前文中 IN 运算符的示例相同。

7.3 短路运算

对于逻辑运算符 AND 和 OR,SQL 使用短路运算(short-circuit evaluation)。也就是说,只要前面的表达式能够决定最终的结果,不执行后面的计算。这样能够提高运算效率。因此,以下语句不会产生除零错误:

SELECT 'AND'
  FROM employee
 WHERE 1 = 0 AND 1/0 = 1;
SELECT 'OR'
  FROM employee
 WHERE 1 = 1 OR 1/0 = 1;

第一个查询由于 AND 左边的结果为假,肯定不会返回任何结果,因此也就不会计算 1/0;第二个查询由于 OR 左边的结果为真,一定会返回结果,同样不会产生除零错误。

7.4 NOT 运算符

NOT 运算符可以结合其他的运算符一起使用,用于对查询条件的结果取反:

  • NOT BETWEEN,位于范围之外
  • NOT IN,不在列表之中
  • NOT LIKE,不匹配某个模式。LIKE 运算符用于字符串的模糊查找,将在下一篇中进行介绍
  • NOT EXISTS,子查询中不存在结果。关于子查询和 EXISTS 运算符,将在第 16 篇中进行介绍
  • NOT IS NULL,不为空。等价于 IS NOT NULL。


以下示例查找除了“刘备”、“关羽”以及“张飞”之外的其他员工:

SELECT emp_id, emp_name
  FROM employee
 WHERE emp_name NOT IN ('刘备', '关羽', '张飞');

该语句的结果如下(显示部分内容):

avatar

将多个逻辑运算符进行组合,可以构造任意复杂的查询条件。不过,需要注意不同的运算符之间的优先级问题。

8 运算符优先级

假如我们想要知道人力资源部(deptid = 2)或者财务部门(deptid = 3)中,哪些员工拥有奖金。如果使用以下查询:

SELECT emp_name, dept_id, bonus
  FROM employee
 WHERE dept_id = 2
    OR dept_id = 3
   AND bonus IS NOT NULL;

获得的结果如下:


avatar


其中有两条数据并不是我们期望的结果(“黄忠”和“魏延”并没有奖金)。那么问题出在哪里了呢?因为 AND 运算符比 OR 运算符的优先级高,所以该查询返回的是人力资源部(deptid = 2)的员工,或者财务部(deptid = 3)中拥有奖金的员工。


如果想要获得我们期望的结果,可以使用圆括号调整运算符的优先级:


SELECT emp_name, dept_id, bonus

FROM employee

WHERE (dept_id = 2 OR dept_id = 3)

AND bonus IS NOT NULL;

正确的结果如下:


avatar


以下是 SQL 中各种条件运算符按照优先级从高到低进行的排列;必要时可以使用圆括号进行调整。


=、!=、<>、<、<=、>、>=

IS [NOT] NULL、[NOT] LIKE、[NOT] BETWEEN、[NOT] IN、[NOT] EXISTS

NOT

AND

OR

除了使用查询条件过滤数据之外,SQL 还提供了一种特殊的数据选择操作:去除查询结果中的重复值。

9 去除重复值

SQL 使用 DISTINCT 关键字去除查询结果中的重复数据。例如,以下查询返回了员工表所有可能的性别:

SELECT DISTINCT sex
  FROM employee;
sex|
---|
男 |
女 |

首先,DISTINCT 位于 SELECT 之后而不是像其他过滤条件一样位于 WHERE 之后;其次,查询结果中重复的记录只会出现一次。


与 DISTINCT 相反的是 ALL,用于返回不去重的结果。我们通常不需要加上 ALL 关键字,因为它是默认的行为。另外,为了消除重复值,数据库系统需要对结果进行排序,然后扫描重复值;因此,大量数据的重复值处理可能会降低查询的速度。


Oracle 中的 UNIQUE 等价于 DISTINCT,MySQL 中的 DISTINCTROW 等价于 DISTINCT。


10 总结

在 SQL 中使用 WHERE 子句指定一个或者多个过滤条件,可以查找满足要求的数据。SQL 查询条件中支持各种比较运算符、逻辑运算符以及空值判断等。另外,DISITINCT 关键字可以去除查询结果中的重复记录。


练习题:查找 2018 年 1 月 1 日之后入职,月薪小于 5000,并且奖金小于 1000(包括没有奖金)的员工。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
3月前
|
SQL 缓存 监控
MySQL缓存机制:查询缓存与缓冲池优化
MySQL缓存机制是提升数据库性能的关键。本文深入解析了MySQL的缓存体系,包括已弃用的查询缓存和核心的InnoDB缓冲池,帮助理解缓存优化原理。通过合理配置,可显著提升数据库性能,甚至达到10倍以上的效果。
|
3月前
|
SQL 存储 关系型数据库
MySQL体系结构详解:一条SQL查询的旅程
本文深入解析MySQL内部架构,从SQL查询的执行流程到性能优化技巧,涵盖连接建立、查询处理、执行阶段及存储引擎工作机制,帮助开发者理解MySQL运行原理并提升数据库性能。
|
5月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
324 0
|
3月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
储存过程(Stored Procedures) 和 函数(Functions) : 储存过程和函数允许用户编写 SQL 脚本执行复杂任务.
248 14
|
3月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
以上概述了MySQL 中常见且重要 的几种 SQL 查询及其相关概念 这些知识点对任何希望有效利用 MySQL 进行数据库管理工作者都至关重要
127 15
|
3月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
3月前
|
SQL 关系型数据库 MySQL
MySQL入门指南:从安装到第一个查询
本文为MySQL数据库入门指南,内容涵盖从安装配置到基础操作与SQL语法的详细教程。文章首先介绍在Windows、macOS和Linux系统中安装MySQL的步骤,并指导进行初始配置和安全设置。随后讲解数据库和表的创建与管理,包括表结构设计、字段定义和约束设置。接着系统介绍SQL语句的基本操作,如插入、查询、更新和删除数据。此外,文章还涉及高级查询技巧,包括多表连接、聚合函数和子查询的应用。通过实战案例,帮助读者掌握复杂查询与数据修改。最后附有常见问题解答和实用技巧,如数据导入导出和常用函数使用。适合初学者快速入门MySQL数据库,助力数据库技能提升。
|
4月前
|
存储 关系型数据库 MySQL
使用命令行cmd查询MySQL表结构信息技巧分享。
掌握了这些命令和技巧,您就能快速并有效地从命令行中查询MySQL表的结构信息,进而支持数据库维护、架构审查和优化等工作。
475 9
|
缓存 关系型数据库 MySQL
MySQL索引策略与查询性能调优实战
在实际应用中,需要根据具体的业务需求和查询模式,综合运用索引策略和查询性能调优方法,不断地测试和优化,以提高MySQL数据库的查询性能。
636 66
|
3月前
|
SQL 监控 关系型数据库
MySQL高级查询技巧:子查询、联接与集合操作
本文深入解析了MySQL高级查询的核心技术,包括子查询、联接和集合操作,通过实际业务场景展示了其语法、性能差异和适用场景,并提供大量可复用的代码示例,助你从SQL新手进阶为数据操作高手。

推荐镜像

更多