mysql 等值连接案例之添加筛选分组排序多表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 等值连接案例之添加筛选分组排序多表相关的知识,希望对你有一定的参考价值。

加筛选

#案例:有奖金的员工名和部门名

SELECT 
    last_name,department_name
FROM
    employees AS e,departments AS d
WHERE
    e.department_id=d.department_id
AND
    e.commission_pct IS NOT NULL;

#案例:查询城市名中第二个字符为o的部门名和城市名

SELECT
    department_name,city
FROM
    departments AS d,locations AS l
WHERE
    d.location_id=l.location_id
AND
    l.city LIKE‘_o%‘;

加分组

#案例:查询每个城市的部门个数

SELECT
    COUNT(*),city
FROM
    departments AS d,locations AS l
WHERE
    d.`location_id`=l.`location_id`
GROUP BY
    city;

#案例:查询有奖金的每个部门的部门名和部门的领导编号和该部门的最低工资

SELECT
    department_name,d.manager_id,MIN(salary)
FROM
    employees AS e,departments AS d
WHERE
    d.department_id=e.department_id
AND
    commission_pct IS NOT NULL
GROUP BY
    department_name,d.manager_id;

加排序
#案例:查询每个工种的工种名和员工的个数,并且按员工个数降序

SELECT
    job_title,COUNT(*)
FROM
    employees AS e,jobs AS j
WHERE
    e.job_id=j.job_id
GROUP BY
    job_title
ORDER BY
    COUNT(*) DESC;

三表连接
#案例:查询员工名 、部门名、所在的城市

SELECT
    last_name,department_name,city
FROM
    employees AS e,departments AS d,locations AS l
WHERE
    e.department_id=d.`department_id`
AND
    d.`location_id`=l.location_id

以上是关于mysql 等值连接案例之添加筛选分组排序多表的主要内容,如果未能解决你的问题,请参考以下文章

Mysql数据库操作总结

连接查询

Mysql查询相关知识(进阶五:分组查询,进阶六 连接查询)

Mysql连表查询

MySql的回顾五:多表查询下(内联/左外/右外/自连接/交叉)-1999语法

mysql 多表查询等值连接为表取别名