Sql me END),null),[MondayIn])作为float)

Sql me END),null),[MondayIn])作为float),sql,sql-server,common-table-expression,Sql,Sql Server,Common Table Expression,me END),null),[MondayIn])作为float)

me END),null),[MondayIn])作为float)<0然后'Late By'+cast(ABS(DATEDIFF(S,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后AccessTime END时的大小写),null),[MondayIn])/3600作为varchar(10))+':'+cast(ABS(DATEDIFF(S,ISNULL(MAX(当ReaderType='IN'和IN=1然后AccessTime END时的大小写),null),[MondayIn])%3600/60作为varchar(10))+'hours' 当强制转换(DATEDIFF(s,ISNULL)(最大值(ReaderType='IN'和IN_RN=1,然后是AccessTime END)时为null),[MondayIn])为float=0,然后为'On Time' else'Early By'+cast(ABS(DATEDIFF(S,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后访问时间结束时的大小写),null),[MondayIn])/3600作为varchar(10))+:'+cast(ABS(DATEDIFF(S,ISNULL)(MAX(当ReaderType='IN'和IN=1然后访问时间结束时的大小写),null),[MondayIn])%3600/60作为varchar(10))+'hours'结束)从[dbo]。[tblBranchTimingEntry]其中BranchEntryID=(从[dbo].[tblBranch]中选择[BranchEntryID],其中[BranchHid]=[Branch])) 那么“星期二”是什么时候 (选择顶部1(案例) 当cast(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后AccessTime END时的大小写为null)时,[TuesdayIn])作为float<0然后“Late By”+cast(ABS(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后AccessTime END时的大小写为null))/3600作为varchar(10))+“:”+cast(ABS(DATEDIFF(s,ISNULL)时的大小写为MAX(当ReaderType='IN'和IN_RN=1时,则为AccessTime END),null),[TuesdayIn])%3600/60为varchar(10))+'hours' 当强制转换(DATEDIFF(s,ISNULL)(最大值(ReaderType='IN'和IN_RN=1,然后是AccessTime END)时为null),[TuesdayIn])为float=0,然后为'On Time' else'Early By'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN_RN=1,然后访问时间结束时为null),[TuesdayIn]))/3600作为varchar(10))+:'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN=1,然后访问时间结束时为null),[TuesdayIn])%3600/60作为varchar(10))+hours)从[dbo]。[tblBranchTimingEntry]其中BranchEntryID=(从[dbo].[tblBranch]中选择[BranchEntryID],其中[BranchHid]=[Branch])) “星期三”是什么时候 (选择顶部1(案例) 当cast(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后AccessTime END时的大小写为null),[WednesdayIn])作为float时,<0然后“Late By”+cast(ABS(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后AccessTime END时的大小写为null),[WednesdayIn])/3600作为varchar(10))+“:”+cast(ABS(DATEDIFF(s,ISNULL)时的大小写为MAX(当ReaderType='IN'和IN_RN=1时,则为AccessTime END),null),[WednesdayIn])%3600/60作为varchar(10))+'hours' 当强制转换(DATEDIFF(s,ISNULL)(最大值(ReaderType='IN'和IN_RN=1,然后是AccessTime END)时为null),[WednesdayIn])为float=0,然后为'On Time' else“Early By”+cast(ABS(DATEDIFF(S,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后访问时间结束时的情况),null),[WednesdayIn])/3600作为varchar(10))+:“+cast(ABS(DATEDIFF(S,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1然后访问时间结束时的情况),null),[WednesdayIn])%3600/60作为varchar(10))+'hours'结束)从[dbo]开始。[tblBranchTimingEntry]其中BranchEntryID=(从[dbo]中选择[BranchEntryID]。[tblBranch]其中[BranchHid]=[Branch])) “星期四”是什么时候 (选择顶部1(案例) 当cast(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后访问时间结束时的大小写),null),[ThursdayIn])作为float<0,然后'Late By'+cast(ABS(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后访问时间结束时的大小写),null),/3600作为varchar(10))+':'+cast(ABS(DATEDIFF(s,ISNULL)(MAX)(MAX(当ReaderType='IN'和IN_RN=1,然后访问时间结束时的大小写),null),[ThursdayIn])%3600/60作为varchar(10))+'hours' 当强制转换(DATEDIFF(s,ISNULL)(最大值(ReaderType='IN'和IN_RN=1,然后是AccessTime END)时为null),[ThursdayIn])为float=0,然后为'On Time' else'Early By'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN_RN=1,然后访问时间结束时为null),[ThursdayIn]))/3600作为varchar(10))+:'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN=1,然后访问时间结束时为null),[ThursdayIn])%3600/60作为varchar(10))+'hours'结束)从[dbo]。[tblBranchTimingEntry]其中BranchEntryID=(从[dbo].[tblBranch]中选择[BranchEntryID],其中[BranchHid]=[Branch])) 那么“星期五”是什么时候 (选择顶部1(案例) 当cast(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后AccessTime END)为null)时,[FridayIn])作为float<0,然后“Late By”+cast(ABS(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后AccessTime END)为null),[FridayIn])/3600作为varchar(10))+“:”+cast(ABS(DATEDIFF(s,ISNULL),MAX(MAX(当ReaderType='IN'和IN_RN=1,然后是AccessTime END时的大小写),null),[FridayIn])%3600/60作为varchar(10))+'hours' 当强制转换(DATEDIFF(s,ISNULL)(最大值(ReaderType='IN'和IN_RN=1,然后是AccessTime END)时为null),[FridayIn])为float=0,然后为'On Time' else'Early By'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN_RN=1,然后访问时间结束时为null),[FridayIn]))/3600作为varchar(10))+:'+cast(ABS(DATEDIFF(S,ISNULL)(最大值(当ReaderType='IN'和IN=1,然后访问时间结束时为null),[FridayIn])%3600/60作为varchar(10))+“小时”结束,从[dbo]。[tblBranchTimingEntry]其中BranchEntryID=(从[dbo].[tblBranch]中选择[BranchEntryID],其中[BranchHid]=[Branch])) 那么“星期六”是什么时候 (选择顶部1(案例) 当cast(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后AccessTime END)为null)时,[SaturdayIn]作为float)<0,然后'Late By'+cast(ABS(DATEDIFF(s,ISNULL)(MAX(当ReaderType='IN'和IN_RN=1,然后AccessTime END)为null),[SaturdayIn])/3600作为varchar(10))+':'+cast(ABS(DATEDIFF(s,ISNULL)(MAX)时(当ReaderType='IN'和IN_RN=1,然后是AccessTime END时的大小写),null),[SaturdayIn])%3600/60作为varchar(10))+'hours' 什么时候
+------------+--------------+----------+-----------------+------------+-------+
| EmployeeId | EmployeeName | Location |   AccessTime    | ReaderType |Branch |
+------------+--------------+----------+-----------------+------------+-------+
| _1346      | A            | L1       | 7/11/2014 10:00 | IN         |NBAD001|
| _1347      | B            | L2       | 7/10/2014 10:58 | IN         |NBAD001|
| _1346      | A            | L3       | 7/11/2014 23:39 | OUT        |NBAD001|
| _1347      | B            | L4       | 7/10/2014 23:58 | OUT        |NBAD001|
| _1364      | C            | L5       | 7/11/2014 10:00 | IN         |NBAD005|
| _1367      | D            | L6       | 7/10/2014 10:58 | IN         |NBAD002|
| _1367      | D            | L7       | 7/10/2014 22:42 | OUT        |NBAD002|
| _1364      | C            | L8       | 7/11/2014 23:58 | OUT        |NBAD005|
| _1422      | E            | L9       | 7/11/2014 23:58 | IN         |NBAD004|
| _1422      | E            | L10      | 7/11/2014 23:10 | IN         |NBAD004|
| _1111      | F            | L20      | 7/10/2014 23:10 | OUT        |NBAD003|
+------------+--------------+----------+-----------------+------------+-------+
+---------------+----------+-------------------+
| BranchEntryId | BranchID |    BranchName     |
+---------------+----------+-------------------+
|            24 | NBAD001  | Motor City Branch |
|            25 | NBAD002  | B2                |
|            26 | NBAD003  | B3                |
|            27 | NBAD004  | B4                |
|            28 | NBAD005  | B5                |
|            29 | NBAD006  | B6                |
|            30 | NBAD007  | B7                |
+---------------+----------+-------------------+
+-------------------+---------------+-----------+-----------+----------+-----------+----------+-----------+-----------+------------+-------------+--------------+------------+-------------+----------+-----------+------------+-------------+
| BranchTimeEntryID | BranchEntryID | fromDate  |  toDate   | SundayIn | SundayOut | MondayIn | MondayOut | TuesdayIn | TuesdayOut | WednesdayIn | WednesdayOut | ThursdayIn | ThursdayOut | FridayIn | FridayOut | SaturdayIn | SaturdayOut |
+-------------------+---------------+-----------+-----------+----------+-----------+----------+-----------+-----------+------------+-------------+--------------+------------+-------------+----------+-----------+------------+-------------+
|                 1 |            24 | 7/10/2014 | 7/30/2014 | 0:00     | 0:00      | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 9:30     | 15:30     | 9:30       | 15:30       |
|                 2 |            24 | 7/1/2014  | 7/9/2014  | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 3 |            25 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 4 |            26 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 5 |            27 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 6 |            28 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 7 |            29 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
|                 8 |            30 | 7/1/2014  | 7/30/2014 | 10:00    | 18:00     | 10:00    | 18:00     | 10:00     | 18:00      | 10:00       | 18:00        | 10:00      | 18:00       | 0:00     | 0:00      | 0:00       | 0:00        |
+-------------------+---------------+-----------+-----------+----------+-----------+----------+-----------+-----------+------------+-------------+--------------+------------+-------------+----------+-----------+------------+-------------+
+-------------+-------------------+---------+-----------+---------+--------------+---------------------+
| Employee ID |       Name        | Branch  |   Date    | In Time | ScheduleTime |    TimeVariance     |
+-------------+-------------------+---------+-----------+---------+--------------+---------------------+
| _1487       | basement paking   | NBAD001 | 10/7/2014 | 23:01   | 10:00        | Late By 13:01 hours  |
| _1346       | CHARLEY BAOUAMINA | NBAD001 | 10/7/2014 | 23:05   | 10:00        | Late By 13:05 hours  |
| _1268       | DANA AZZI         | NBAD001 | 10/7/2014 | 23:51   | 10:00        | Late By 13:51 hours |
| _1585       | DANA AZZI         | NBAD003 | 10/7/2014 | 23:48   | 0:00         | Late By 23:48 hours |
+-------------+-------------------+---------+-----------+---------+--------------+---------------------+
    ;WITH CTE AS(
    SELECT
        EmployeeID,
        EmployeeName,
        [Branch],
        AccessDate = CAST(AccessTime AS DATE),
        AccessTime = CAST(AccessTime AS TIME),
        Location,
        ReaderType,
        In_RN = ROW_NUMBER() OVER(PARTITION BY EmployeeId, CAST(AccessTime AS DATE), ReaderType ORDER BY CAST(AccessTime AS TIME) ASC)
        --Out_RN = ROW_NUMBER() OVER(PARTITION BY EmployeeId, CAST(AccessTime AS DATE), ReaderType ORDER BY CAST(AccessTime AS TIME) DESC)
    FROM tblAccess
    where CAST(AccessTime AS DATE) between '2014-07-10' and '2014-07-11'
    AND ReaderType = 'IN'
)
SELECT
ROW_NUMBER() OVER (ORDER BY EmployeeID) AS [Sl No],
    EmployeeID as[Employee ID],
    EmployeeName as [Name],
    [Branch],
    [Date] = CONVERT(VARCHAR(10), AccessDate, 103),
    [In Time] = ISNULL(SUBSTRING(CONVERT(VARCHAR(20), MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END)), 1, 5), '')
    , ScheduleTime =
         CASE DATENAME(DW,AccessDate)
         WHEN 'Sunday' THEN (select TOP 1 (( SUBSTRING( convert(varchar, [SundayIn],108),1,5))) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Monday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [MondayIn],108),1,5) )) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Tuesday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [TuesdayIn],108),1,5))) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Wednesday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [WednesdayIn],108),1,5) )) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Thursday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [ThursdayIn],108),1,5))) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Friday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [FridayIn],108),1,5) )) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
         WHEN 'Saturday' THEN (select TOP 1 ((SUBSTRING( convert(varchar, [SaturdayIn],108),1,5) )) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))
           END
    , TimeVariance =
      CASE DATENAME(DW,AccessDate)
        WHEN 'Sunday' THEN 
            (select TOP 1( case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SundayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))

        WHEN 'Monday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[MondayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))


        WHEN 'Tuesday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[TuesdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))


        WHEN 'Wednesday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[WednesdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))


        WHEN 'Thursday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[ThursdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))

        WHEN 'Friday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[FridayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))

        WHEN 'Saturday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,ISNULL(MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN AccessTime END), null),[SaturdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]))

      END
FROM CTE 
WHERE In_RN = 1
GROUP BY EmployeeID, EmployeeName, AccessDate, [Branch]
ORDER BY EmployeeName, AccessDate
select a.EmployeeId, a.Branch, 
       (case when cast(cast(accesstime as date) as datetime) + sundayin) < accesstime
             then 'Late by '
             else 'Early by '
        end) +
       (cast (case when DATENAME(DW, AccessDate) = 'Sunday'
                   then datediff(second, accesstime,
                                 cast(cast(accesstime as date) as datetime) + sundayin)
                   when . . .
              end) as varchar(255)) + ' seconds'
from (select a.*,
             row_number() over (partition by employeeid, cast(accesstime as date) order by accesstime) as seqnum
      from tblAccess a
      where CAST(AccessTime AS DATE) between @DateFrom and @DateTo AND
            ReaderType = 'IN'
     ) a join
     tblBranch b
     on a.branch = b.branchid and a.seqnum = 1 join
     tblBranchTimingEntry bte
     on b.BranchTimeEntryID = bte.BranchTimeEntryID
;WITH CTE AS(
    select 
    EmployeeID,
        EmployeeName,
        [Branch],
        [Date] = CAST(AccessTime AS DATE),
        [InTime] = CAST(AccessTime AS TIME),
        ReaderType,
        In_RN = ROW_NUMBER() OVER(PARTITION BY EmployeeId, CAST(AccessTime AS DATE), ReaderType ORDER BY CAST(AccessTime AS TIME) ASC)
    from
    [dbo].[tblAccess] A
    where a.ReaderType = 'IN'
    and CAST(AccessTime AS DATE) between '2014-07-01' and '2014-07-30'
)

select 
EmployeeID as[Employee ID],
    EmployeeName as [Name],
    [Branch],
    [Date] = CONVERT(VARCHAR(10), [Date], 103),
    [In Time] = ISNULL(SUBSTRING(CONVERT(VARCHAR(20), MAX(CASE WHEN ReaderType = 'IN' AND In_RN = 1 THEN [InTime] END)), 1, 5), ''),
    CASE DATENAME(DW,[Date])
         WHEN 'Sunday' THEN (select (SUBSTRING( convert(varchar, [SundayIn],108),1,5)) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Monday' THEN (select (SUBSTRING( convert(varchar, [MondayIn],108),1,5) ) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Tuesday' THEN (select (SUBSTRING( convert(varchar, [TuesdayIn],108),1,5)) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Wednesday' THEN (select (SUBSTRING( convert(varchar, [WednesdayIn],108),1,5) ) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Thursday' THEN (select (SUBSTRING( convert(varchar, [ThursdayIn],108),1,5)) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Friday' THEN (select (SUBSTRING( convert(varchar, [FridayIn],108),1,5) ) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
         WHEN 'Saturday' THEN (select (SUBSTRING( convert(varchar, [SaturdayIn],108),1,5) ) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)
    END as [ScheduledTime]
, TimeVariance =
      CASE DATENAME(DW,[date])
        WHEN 'Sunday' THEN 
            (select TOP 1( case 
            when cast(DATEDIFF(s,[InTime],[SundayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[SundayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[SundayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[SundayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[SundayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[SundayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)

        WHEN 'Monday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[MondayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[MondayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[MondayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[MondayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[MondayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[MondayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)


        WHEN 'Tuesday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[TuesdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[TuesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[TuesdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[TuesdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[TuesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[TuesdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)


        WHEN 'Wednesday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[WednesdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[WednesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[WednesdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[WednesdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[WednesdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[WednesdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)


        WHEN 'Thursday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[ThursdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[ThursdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[ThursdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[ThursdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[ThursdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[ThursdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)

        WHEN 'Friday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[FridayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[FridayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[FridayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[FridayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[FridayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[FridayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)

        WHEN 'Saturday' THEN 
            (select TOP 1(case 
            when cast(DATEDIFF(s,[InTime],[SaturdayIn]) as float) < 0 then 'Late By '+ cast(ABS(DATEDIFF(S,[InTime],[SaturdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[SaturdayIn]))%3600/60 as varchar(10))+ ' hours' 
            when cast(DATEDIFF(s,[InTime],[SaturdayIn]) as float) = 0 then 'On Time'
            else 'Early By '+ cast(ABS(DATEDIFF(S,[InTime],[SaturdayIn]))/3600 as varchar(10))+ ':'+ cast(ABS(DATEDIFF(S,[InTime],[SaturdayIn]))%3600/60 as varchar(10))+ ' hours' end) from [dbo].[tblBranchTimingEntry] where BranchEntryID= (select [BranchEntryId] from [dbo].[tblBranch] where [BranchID]= [Branch]) and [Date] between fromDate and toDate)

      END
from CTE where In_RN = 1
GROUP BY EmployeeID, EmployeeName, [Date], [Branch], [InTime]
ORDER BY EmployeeName, [Date]