还不会使用MySQL的复合查询?一篇文章快速教会你

使用逻辑运算符

  • AND 用于同时满足多个条件。
  • OR 用于满足任一条件
mysql 复制代码
SELECT * FROM employees WHERE department = 'Sales' AND salary > 50000;
  • employees 表中选取所有在 "Sales" 部门工作且薪水高于50,000的员工记录。

子查询

子查询是在一个 SELECT 语句中嵌套另一个 SELECT 语句,用于从一个表中获取数据作为另一个查询的条件。

mysql 复制代码
SELECT * FROM employees 
WHERE department_id IN (SELECT id FROM departments WHERE location = 'New York');
  • employees 表中选取所有属于位于 "New York" 部门的员工记录。具体来说,它首先找到所有在 "New York" 的部门 ID,然后再找出这些部门中的员工信息。

JOIN操作

JOIN 操作允许你从多个表中结合相关的数据,常见的有 INNER JOIN、LEFT JOIN 等

mysql 复制代码
SELECT e.name, d.department_name 
FROM employees e 
INNER JOIN departments d ON e.department_id = d.id;
  • employees 表和 departments 表中选择所有员工的姓名及其对应部门名称。只有当员工的部门 ID 与相应部门的 ID 匹配时,相关记录才会被选中。

UNION

UNION 将两个或多个 SELECT 查询结果合并为一个结果集

mysql 复制代码
SELECT name FROM employees WHERE department = 'Sales'
UNION
SELECT name FROM contractors WHERE project = 'Project A';
  • employees 表中获取所有在 "Sales" 部门工作的员工姓名,
  • contractors 表中获取所有参与 "Project A" 项目的承包商姓名,
  • 最后,将这两个结果集合并成一个结果集,并去除重复项。

UNION ALL

UNION 默认去重,而 UNION ALL 则保留重复项。

mysql 复制代码
SELECT name FROM employees WHERE department = 'Sales'
UNION ALL
SELECT name FROM contractors WHERE project = 'Project A';
  • employees 表中获取所有在 "Sales" 部门工作的员工姓名,以及
  • contractors 表中获取所有参与 "Project A" 项目的承包商姓名,
  • 最后,将这两个结果集合并成一个结果集,并保留重复项(如果存在)。

CASE 语句

mysql 复制代码
SELECT name,
       CASE 
           WHEN salary > 70000 THEN 'High'
           WHEN salary BETWEEN 50000 AND 70000 THEN 'Medium'
           ELSE 'Low'
       END AS salary_category
FROM employees;
  • employees 表中获取所有员工的姓名和对应的薪资类别。
  • 根据每位员工的薪资,将其分为三类:高、中或低。

GROUP BY 与 HAVING

GROUP BY 用于对结果进行分组,HAVING 用于过滤分组后的结果集

mysql 复制代码
SELECT department, COUNT(*) as employee_count 
FROM employees 
GROUP BY department 
HAVING employee_count > 10;
  • 从一个名为employees的数据库表中统计每个部门的员工数量,并筛选出员工数量超过10人的部门
相关推荐
一个public的class1 小时前
什么是 Java 泛型
java·开发语言·后端
士别三日&&当刮目相看1 小时前
JAVA学习*Object类
java·开发语言·学习
我有医保我先冲1 小时前
SQL复杂查询与性能优化:医药行业ERP系统实战指南
数据库·sql·性能优化
快来卷java1 小时前
MySQL篇(一):慢查询定位及索引、B树相关知识详解
java·数据结构·b树·mysql·adb
凸头2 小时前
I/O多路复用 + Reactor和Proactor + 一致性哈希
java·哈希算法
阳光_你好2 小时前
详细说明Qt 中共享内存方法: QSharedMemory 对象
开发语言·数据库·qt
慵懒学者2 小时前
15 网络编程:三要素(IP地址、端口、协议)、UDP通信实现和TCP通信实现 (黑马Java视频笔记)
java·网络·笔记·tcp/ip·udp
anda01092 小时前
11-leveldb compact原理和性能优化
java·开发语言·性能优化
喝醉酒的小白3 小时前
MySQL响应慢是否由堵塞或死锁引起?
数据库
Pasregret3 小时前
04-深入解析 Spring 事务管理原理及源码
java·数据库·后端·spring·oracle