2

我被要求确定员工在 microsoft access 中保存的数据库中完成一项任务的时间。基本上,一个表包含员工 ID、任务标识符(工作编号)、状态(1 表示工作开始,2 表示工作结束)和事件的日期时间。

只有一个人可以从事任何工作,一旦开始,他们必须在开始另一项任务之前完成任务。数据库中的条目可能看起来像

EmpID          TaskID        TaskStatus       TaskDate
1              A001          1                15/09/12 09:00
2              A023          1                15/09/12 09:00
1              A001          2                15/09/12 09:30
3              A011          1                15/09/12 09:35
3              A011          2                15/09/12 09:45
1              A016          1                15/09/12 09:45
2              A023          2                15/09/12 09:45
..

我需要制作一份报告,显示

EmpID          TaskID        Time Take
1              A001          0:30
2              A023          0:45
3              A011          0:10

除此之外,我只需要列出那些花费少于给定持续时间的任务(用于确保在快速完成的工作中仍能满足质量标准)。

感谢所有帮助。

4

2 回答 2

1

此查询将为您提供每个TaskID. 未完成的任务(没有带有 的行TaskStatus=2)将返回 Null 作为持续时间。INNER JOIN如果您希望排除未完成的任务,则可以改用。

SELECT
    strt.EmpID,
    strt.TaskID,
    DateDiff('n',strt.TaskDate,stp.TaskDate) AS minutes_taken
FROM
    YourTable AS strt
    LEFT JOIN (
            SELECT TaskID, TaskDate
            FROM YourTable
            WHERE TaskStatus=2
        ) AS stp
    ON strt.TaskID = stp.TaskID
WHERE strt.TaskStatus=1;

注意我只TaskID用于加入条件,因为“只有一个人可以从事任何工作,一旦开始,他们必须在开始另一个任务之前完成任务”。如果我的解释有误,请更改ON条款。

基于该查询构建另一个查询以过滤结果minutes_taken

PARAMETERS target Short;
SELECT
    sub.EmpID
    sub.TaskID
    sub.minutes_taken
FROM
    (
        SELECT
            strt.EmpID,
            strt.TaskID,
            DateDiff('n',strt.TaskDate,stp.TaskDate) AS minutes_taken
        FROM
            YourTable AS strt
            LEFT JOIN (
                    SELECT TaskID, TaskDate
                    FROM YourTable
                    WHERE TaskStatus=2
                ) AS stp
            ON strt.TaskID = stp.TaskID
        WHERE strt.TaskStatus=1
    ) AS sub
WHERE sub.minutes_taken < target;
于 2012-10-10T10:13:22.980 回答
0

尝试这样的事情:

这是 SQL server 语法,确实需要将其转换为 ms 访问,我认为您唯一需要隐蔽的是 cast 函数,它将数字转换为字符串

 select t1.EmpID,
        t1.TaskID,
        cast(datediff('n',t1.TaskDate,t2.TaskDate)/60 as varchar(10))+' : '+
        cast(datediff('n',t1.TaskDate,t2.TaskDate)%60 as char(2)) as TimeTaken
 from   table1 t1
 inner join   table1 t2
 on     t1.EmpID=t2.EmpID
 and    t1.TaskID=t2.TaskID
 where  t1.TaskStatus=1
 and    t2.TaskStatus=2


SQL小提琴演示

于 2012-10-10T09:02:19.537 回答