在SQL中,子查询(subquery)是一种嵌套在另一个查询中的查询。子查询可以出现在SELECT、FROM、WHERE和HAVING子句中。使用子查询进行数据聚合可以帮助你在一个查询中完成复杂的操作。以下是一些使用子查询进行数据聚合的示例:
SELECT department_id, AVG(salary) as avg_salary
FROM employees
WHERE department_id IN (
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary) > (SELECT AVG(salary) FROM employees)
);
SELECT department_id, COUNT(*) as employee_count
FROM employees
WHERE department_id IN (
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT(*) > 5
);
SELECT product_id, MAX(sales) as max_sales
FROM sales
WHERE product_id IN (
SELECT product_id
FROM sales
GROUP BY product_id
ORDER BY MAX(sales) DESC
LIMIT 1
);
SELECT department_id, COUNT(*) as employee_count
FROM employees
GROUP BY department_id
ORDER BY (
SELECT COUNT(*)
FROM employees e2
WHERE e2.department_id = employees.department_id
) DESC;
这些示例展示了如何使用子查询进行数据聚合。你可以根据自己的需求修改查询条件和聚合函数。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。