温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

mysql数据库子查询的实例用法

发布时间:2021-09-10 09:27:28 来源:亿速云 阅读:138 作者:chen 栏目:MySQL数据库

本篇内容介绍了“mysql数据库子查询的实例用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

#查询和Zlotkey相同部门的员工姓名和工资

SELECT last_name,salary
FROM employees
WHERE department_id=(
    SELECT department_id
    FROM employees
    WHERE last_name='Zlotkey'
);

#查询工资比公司平均工资高的员工的员工号、姓名和工资

SELECT employee_id,last_name,salary
FROM employees
WHERE salary>(
    SELECT AVG(salary)
    FROM employees
);

#查询各部门中工资比本部门平均工资高的员工号、姓名和工资
注:连接员工表和平均工资表,再筛选

SELECT employee_id,last_name,salary
FROM (
    SELECT AVG(salary) s,department_id
    FROM employees 
    GROUP BY department_id
) a
INNER JOIN employees e
ON a.department_id=e.department_id
WHERE e.salary>s;

#查询和姓名中包含字母u的员工在相同部门的员工的员工号和姓名
先查询包含u员工的部门id,再查id相同情况

SELECT employee_id,last_name
FROM employees
WHERE department_id IN(
    SELECT DISTINCT department_id
    FROM employees
    WHERE last_name LIKE '%u%'
);

#查询在部门的location_id为1700的部门工作的员工的员工号
注先查询location_id等于1700的部门编号,在查询员工号

SELECT employee_id
FROM employees e
WHERE e.`department_id` IN(
    SELECT department_id
    FROM departments d
    WHERE d.`location_id`=1700
)

#查询管理者是K_ing的员工姓名和工资,有两个K_ing

SELECT last_name,salary
FROM employees e
WHERE e.manager_id IN(
    SELECT `employee_id`
    FROM employees m
    WHERE `last_name`='K_ing'
);

#查询工资最高的员工的姓名,要求first_ame和last_name 显示为一列,列名为 姓.名
#起别名有特殊字符需要用引号括起来

SELECT CONCAT(first_name,last_name) '姓.名'  
FROM employees e
WHERE e.salary=(
    SELECT MAX(salary)
    FROM employees
);

“mysql数据库子查询的实例用法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI