MySql的回顾六:子查询(内查询)
西北望乡何处是,东南见月几回圆。
月亮又慢悠悠的挂上了天空,趁着睡前梦呓,我就带领各位可爱的读者们探索MySql最后的子查询部分。
说明:有些查询结果出来结果截图与题目要求不一样会出现多余的字段是为了方便展示结果的可读性。实际操作的读者可以删除SELECT后面多余的字段得到正确的结果。
#WHERE或HAVING后面
#1.标量子查询(单行子查询)
#2.列子查询(多行子查询)
#3.行子查询(多列多行)
#特点:
# ①子查询放在小括号内
# ②子查询一般放在条件的右侧
# ③标量子查询:一般搭配着单行操作符使用
# 单行操作符:> < >= <= <> !-# 列子查询,一般搭配着多行操作符使用
# IN,ANY/SOME(任意),ALL
# ④子查询的执行优先与主查询执行,主查询的条件用到了子查询的结果。
#1.标量子查询
#案例1:谁的工资比Abel高?
#①查询Abel的工资
SELECT salary
FROM employees
WHERE last_name= "Abel";

#案例2.返回job_id与141号员工相同,salary比143号员工多的员工姓名,job_id,工资。
#①查141员工的job_id
SELECT job_id
FROM employees
WHERE employee_id="141";

#③最后合并结果
SELECT CONCAT(last_name,first_name) AS 姓名,
job_id AS 工种编号,
salary AS 工资
FROM employees
WHERE job_id=(
SELECT job_id
FROM employees
WHERE employee_id="141"
)
AND salary>(
SELECT salary
FROM employees
WHERE employee_id="143");

SELECT
last_name AS 姓,
salary AS 工资,
job_id AS 工种编号
FROM employees
WHERE salary=(
SELECT MIN(salary)
FROM employees
);

#分组后,筛选条件①.【不用排除没有部门的所以不筛选部门编号】
SELECT department_id AS 部门编号,
MIN(salary) AS 月薪
FROM employees
#WHERE department_id
GROUP BY department_id
HAVING 月薪>(
SELECT MIN(salary)
FROM employees
);

#案例1.返回location_id是1400或1700的部门中的所有员工姓名。
#①查询location_id是1400或1700的部门编号
SELECT DISTINCT department_id
FROM departments
WHERE location_id IN(1400,1700);
1400,1700)
);
#案例.返回location_id不是1400或1700的部门中的所有员工姓名。
SELECT CONCAT(last_name,first_name) AS 姓名
FROM employees
WHERE department_id NOT IN(
SELECT DISTINCT department_id
FROM departments
WHERE location_id IN(1400,1700)
);==============================SELECT CONCAT(last_name,first_name) AS 姓名
FROM employees
WHERE department_id <> ALL(
SELECT DISTINCT department_id
FROM departments
WHERE location_id IN(1400,1700)
);
SELECT DISTINCT salary
FROM employees
WHERE job_id="IT_PROG";

#③合并①与②在员工表中查出来
SELECT employee_id AS 员工编号,
CONCAT(last_name,first_name) AS 姓名,
job_id AS 工种编号,
salary AS 工资
FROM employees
WHERE job_id!= "IT_PROG"
AND salary
SELECT salary
FROM employees
WHERE job_id="IT_PROG"
);
#案例3.返回其他部门中比job_id为‘IT_PROG’部门所有工资都低的员工
#的员工号,姓名,job_id以及salary。
#①先把IT_PROG部门的工资查出来。
SELECT DISTINCT salary
FROM employees
WHERE job_id="IT_PROG";
=============================MIN替代ALL
SELECT employee_id AS 员工号,
CONCAT(last_name,first_name) AS 姓名,
job_id AS 工种编号,
salary AS 工资
FROM employees
WHERE salary
SELECT MIN(salary)
FROM employees
WHERE job_id="IT_PROG"
)
AND job_id <> "IT_PROG";

SELECT *
FROM employees
WHERE employee_id = (
SELECT MIN(employee_id)
FROM employees
)
AND salary = (
SELECT MAX(salary)
FROM employees
);
#二.SELECT子查询#仅仅支持标量子查询,结果是一行一列
#案例1.查询每个部门的员工个数
SELECT d.*,(SELECT COUNT(*) FROM employees)
FROM departments d;

#案例2.查询员工号=102的部门名。
SELECT department_name
FROM departments;==============SELECT employee_id
FROM employees
WHERE employee_id = 102;


SELECT e.平均工资,j.grade_level
FROM job_grades AS j
,(
SELECT ROUND(AVG(salary),2) AS 平均工资,department_id
FROM employees
GROUP BY department_id
) AS e
WHERE e.平均工资 BETWEEN j.lowest_sal AND j.highest_sal;
#1999语法,老师答案
SELECT e.*,j.grade_level
FROM (
SELECT ROUND(AVG(salary),2) AS 平均工资,department_id
FROM employees
GROUP BY department_id
) AS e
INNER JOIN job_grades j
ON e.平均工资 BETWEEN j.lowest_sal AND j.highest_sal;

查询工资3W的员工信息SELECT EXISTS(SELECT * FROM employees WHERE salary=30000);

#查部门名
SELECT department_name
FROM departments;
=d.department_id;
*
FROM employees e
WHERE d.department_id=e.department_id
);
#案例2.查询没有女朋友的男神信息
#IN方法
SELECT *
FROM boys bo
WHERE bo.id NOT IN(
SELECT boyfriend_id
FROM beauty be
);
===============
#EXISTS方法
SELECT *
FROM boys bo
WHERE NOT EXISTS(
SELECT boyfriend_id
FROM beauty be
WHERE bo.id=be.boyfriend_id
);
#引入案例1.:查询部门编号>90或者邮箱包含A的员工信息
SELECT* FROM employees
WHERE email LIKE "%a%" OR department_id>90;
联合查询
SELECT* FROM employees WHERE email LIKE "%a%"
UNION
SELECT * FROM employees WHERE department_id>90;

感谢能认真读到这里的伙伴们,MySql查询部分结束,相信屏幕前的你照着我博客里的模板可以完成一些简单的SQL查询语句,SQL既然学了,以后还是要多练习一下,SQL1992与1999语法在主流的关系型数据库都是通用的。后续我会继续进行对MySql的知识进行扩展,感兴趣的同志互相关注一呗!o(^▽^)o
MySql的回顾六:子查询(内查询)相关教程
本文深入探讨了MySQL中的子查询,包括标量子查询、列子查询和行子查询。通过实例展示了如何利用子查询进行条件过滤,如找出工资高于Abel的员工、特定job_id的最低工资等。同时讲解了IN、ANY/SOME、ALL等多行操作符的使用,并探讨了子查询与主查询的执行顺序。文章还涉及了SELECT子查询和联合查询的应用,帮助读者掌握SQL查询的更多技巧。

被折叠的 条评论
为什么被折叠?



