2012-09-13 4 views
0

나는 올바르게 끝내는 것이 쉽지 않을까 생각합니다. 각 사용자 (아이디) 아래의 스크린 샷 저장 프로 시저를 사용하는 SQL Server 2008 최종 선택 명령

내가 사용자

(각 사용자 당 하나의 결과를 얻기 위해 쿼리를 해결할 수있는 방법을

(중복의 일종)이 개 결과를 가지고 "TimeIn"및 "TimeOut"활동의 두 세트를 가질 수 있습니다)

따라서 주어진 사용자가 두 번째 "입구"를 가지지 만 아직 떠나지 않은 경우 첫 번째 닫힌 입구/나가기 + 두 번째 입구/아직 작동하지 않아야합니다.

여기

6,338,는

create table #tmp (tId int, UserId int, 
    TimeIn1 smalldatetime, [TimeOut1] smalldatetime, 
    TimeIn2 smalldatetime, [TimeOut2] smalldatetime, tId2 int, 
    ActiveDate smalldatetime, ReasonID int, Name nvarchar(100), ReasonType nvarchar(100), 
    TotalMins int) 

    insert into #tmp (tId, UserId, TimeIn1, TimeOut1, ActiveDate, ReasonID, Name, ReasonType) 
    SELECT 
    t1.tId, t1.UserId, t1.TimeIn, t1.[TimeOut], t1.ActiveDate, t1.ReasonID, tblCustomers.name,tblTimeReas.ReasonType 
    FROM tblTime t1 
    inner join tblTimeReas on t1.ReasonID = tblTimeReas.ReasonID 
    inner join tblCustomers on t1.UserId=tblCustomers.custID 
    where (t1.userid in (select custID from tblCustomers where Classification =35)) 
    and (DATEPART(DAY,t1.timein)= DATEPART(DAY,GETDATE())) 
    and (DATEPART(MONTH,t1.timein)= DATEPART(MONTH,GETDATE())) 
    and (DATEPART(YEAR,t1.timein)= DATEPART(YEAR,GETDATE())) 

    update #tmp 
    set tId2 = (select top 1 tId from 
    tblTime t2 where (userid in (select custID from tblCustomers where Classification =35)) and DATEDIFF(day,t2.timein,#tmp.timein1)=0 
        and t2.tId>#tmp.tId order by tId asc) 


    update #tmp 
    set TimeIn2 = (select TimeIn from tblTime where tId=tId2), 
     TimeOut2 = (select [TimeOut] from tblTime where tId=tId2) 


    update #tmp set TotalMins = (
     isnull(DATEDIFF(minute,timein1,timeout1),0)+ 
     isnull(DATEDIFF(minute,timein2,timeout2),0) 

    ) 

    select * from #tmp order by TimeIn1 
    drop table #tmp 

답변

0

내가 SQL 서버 &, 데이타베이스에 대한 과정을 고려하지 않은 방법, 잘 모릅니다 저장 프로 시저하지만이 훨씬 아주 유연 필터링

create table #tmp (tId int, UserId int, 
    TimeIn1 smalldatetime, [TimeOut1] smalldatetime, 
    ActiveDate smalldatetime, ReasonID int, Name nvarchar(100), ReasonType nvarchar(100), 
    TotalMins int) 

    insert into #tmp (tId, UserId, TimeIn1, TimeOut1, ActiveDate, ReasonID, Name, ReasonType) 
    SELECT 
    t1.tId, t1.UserId, t1.TimeIn, t1.[TimeOut], t1.ActiveDate, t1.ReasonID, tblCustomers.name,tblTimeReas.ReasonType 
    FROM tblTime t1 
    inner join tblTimeReas on t1.ReasonID = tblTimeReas.ReasonID 
    inner join tblCustomers on t1.UserId=tblCustomers.custID 
    where (t1.userid in (select custID from tblCustomers where Classification Like '%,35%')) 
    and (DATEPART(DAY,t1.timein)= DATEPART(DAY,GETDATE())) 
    and (DATEPART(MONTH,t1.timein)= DATEPART(MONTH,GETDATE())) 
    and (DATEPART(YEAR,t1.timein)= DATEPART(YEAR,GETDATE())) 
    and TimeOut is null 


    update #tmp set TotalMins = (
     isnull(DATEDIFF(minute,timein1,GETDATE()),0) 
    ) 

    select *from #tmp order by TimeIn1 
    drop table #tmp 
내 마지막 코드
관련 문제