【发布时间】:2015-04-20 19:07:57
【问题描述】:
我的子查询有问题。 所以我想列出总工作时间大于所有员工平均总工作时间的员工。 但是使用此代码,它会将一名员工的工作时间与另一名员工每小时的工作时间进行比较。 所以这是总结: 员工总工作时间 > 所有员工总工作时间的平均值 --> WHERE hrs_worked > AVG(SUM(HRS_WORKED)) 这就是我想要的。
SELECT employee.emp_id,
employee.emp_name,
SUM(action.hrs_worked) AS "Total Hours Worked"
FROM action
INNER JOIN allocation ON action.act_id = allocation.act_id
AND action.emp_id = allocation.emp_id
INNER JOIN employee ON allocation.emp_id = employee.emp_id
WHERE action.hrs_worked >
(SELECT AVG(action.hrs_worked)
FROM action)
GROUP BY employee.emp_id,
employee.emp_name
ORDER BY SUM(action.hrs_worked) DESC
【问题讨论】:
-
如果您愿意,请考虑遵循以下简单的两步操作: 1. 如果您还没有这样做,请提供适当的 DDL(和/或 sqlfiddle),以便我们可以更轻松地复制问题。 2. 如果您尚未这样做,请提供与步骤 1 中提供的信息相对应的所需结果集。