1.定义 WITH 子句是 MySQL 中的一种 SQL 结构,又称为 Common Table Expression (CTE)。它在不影响原有 SQL 语句的情况下,允许开发人员临时创建一个内存中的结果集,然后对其进行操作。
2.用途 WITH 子句的主要用途是创建一个暂时的结果集,这个结果集在后续的查询中可以多次使用。WITH 子句主要用于解决查询复杂度高的问题,因为它可以将多次需要的计算结果集存储下来,以便后续的查询可以直接使用。它还可以帮助我们更好地组织复杂的 SQL 查询,使得代码更加清晰易读。
1.语法 WITH 子句的语法形式如下:
WITH cte_name (column_name1, column_name2, ...) AS ( SELECT column1, column2, ... FROM table WHERE condition )
其中,cte_name 是 WITH 子句的名称;column_name1、column_name2 等是结果集的列名;SELECT 子句定义了该结果集的内容;condition 是查询的过滤条件。
2.使用示例 首先,假设我们有一个名为“employees”的表,其中包含以下内容:
CREATE TABLE employees (
employee_id INT PRIMARY KEY,
first_name VARCHAR(50),
last_name VARCHAR(50),
salary INT
);
接下来,我们填充数据:
INSERT INTO employees (employee_id, first_name, last_name, salary)
VALUES
(1, 'John', 'Doe', 50000),
(2, 'Jane', 'Doe', 55000),
(3, 'Jim', 'Smith', 60000),
(4, 'Sarah', 'Johnson', 65000),
(5, 'Tom', 'Brown', 70000);
得到原标数据:
id | name_f | name_l | salary |
1 | john | doe | 50000 |
2 | jame | doe | 55000 |
3 | jim | doe | 60000 |
4 | sarah | smith | 65000 |
5 | tom | brown | 70000 |
现在,我们可以使用 WITH 子句创建一个临时结果集,以计算每个员工的月薪:
WITH monthly_salary AS (
SELECT employee_id, first_name, last_name, salary/12 AS monthly_salary
FROM employees
)
SELECT *
FROM monthly_salary;
创建临时结果集的结果为:
id | name_f | name_l | salary/12 |
1 | john | doe | 4166.666 |
2 | jame | doe | 4583.333 |
3 | jim | doe | 5000.000 |
4 | sarah | smith | 5,416.666 |
5 | tom | brown | 5,833.333 |