如何使用mysql从子查询中总计总计

时间:2013-06-04 16:35:46

标签: mysql

我有一个现有的查询,每天为每位员工计算总小时数。我需要在每个员工的两个给定日期之间获得总时数。所以基本上我需要总结每个员工的小时栏。 这是我现有的查询,每天提供总计:

SELECT CONCAT(pe.first, ' ', pe.last) AS Name,
           tp.EmpID AS 'Empl ID',
           DATE_FORMAT(tp.PunchDateTime, '%m-%d-%Y') AS 'Punch Date',
           TRUNCATE(
              (  SUM(UNIX_TIMESTAMP(PunchDateTime) * (1 - 2 * `In-Out`))
               / 3600),
              2)
              AS 'Hours Worked'
      FROM    timeclock_punchlog tp
           LEFT JOIN
              prempl01 pe
           ON tp.EmpID = pe.prempl
     WHERE     tp.PunchDateTime >= '2013-5-26'
           AND tp.PunchDateTime < '2013-6-1'
    GROUP BY date(PunchDateTime), EmpID
    ORDER BY EmpID ASC

它输出如下:

Name                Empl ID Punch Date  Hours Worked
TERESA A. EUBANKS   0354    05-29-2013      0.00
TRACY D CURTIS      0364    05-28-2013      6.15
TRACY D CURTIS      0364    05-29-2013      0.00
KENT KADAVY         0452    05-31-2013      2.38
JANE M SMITH        0456    05-31-2013      0.02
JANE M SMITH        0456    05-29-2013      0.01
JANE M SMITH        0456    05-28-2013      3.15
CINDY JEAN ARREY    0458    05-28-2013      8.16

基本上我想要一个查询,它将获取上面的输出并显示每个员工工作小时数的总和。我不需要显示每天的工作时间。

谢谢! 麦克

1 个答案:

答案 0 :(得分:0)

我正在努力复杂化。不需要子查询。这是我最终的查询,以产生我想要的结果。

    SELECT CONCAT(pe.first, ' ', pe.last) AS Name,
       tp.EmpID AS 'Empl ID',
       DATE_FORMAT(tp.PunchDateTime, '%m-%d-%Y') AS 'Punch Date',
       TRUNCATE(
          (SUM(UNIX_TIMESTAMP(PunchDateTime) * (1 - 2 * `In-Out`)) / 3600),
          3)
          AS 'Hours Worked'
  FROM timeclock_punchlog tp LEFT JOIN prempl01 pe ON tp.EmpID = pe.prempl
 WHERE tp.PunchDateTime >= '2013-5-1' AND tp.PunchDateTime < '2013-5-28'
GROUP BY tp.EmpID;