TECHNOLOGIES
FORUMS
JOBS
BOOKS
EVENTS
INTERVIEWS
Live
MORE
LEARN
Training
CAREER
MEMBERS
VIDEOS
NEWS
BLOGS
Sign Up
Login
No unread comment.
View All Comments
No unread message.
View All Messages
No unread notification.
View All Notifications
Answers
Post
An Article
A Blog
A News
A Video
An EBook
An Interview Question
Ask Question
Forums
Monthly Leaders
Forum guidelines
Prateek Singla
768
1.1k
1.6k
Optimizing the Sql Query
Sep 18 2018 7:35 AM
Hello EveryOne
I am getting issue that this strored procedure is taking long time to execute. Kindly Provide me some solution to optimize this sql query. Thanks for help.
GO
/****** Object: StoredProcedure [dbo].[Usp_AgentTimeSheetReport_byStation] Script Date: 09/18/2018 18:01:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- Select * from station
-- [Usp_AgentTimeSheetReport_byStation] '08/03/2018',5
--[Usp_AgentTimeSheetReport_byStation] '09/21/2018',5
ALTER Proc [dbo].[Usp_AgentTimeSheetReport_byStation]
(
--@StartDate datetime,
@PayRollEndDate datetime,
@StationID int
)
as
Begin
Declare @W1SD datetime
Declare @W1ED datetime
Declare @W2SD datetime
Declare @W2ED datetime
SET @W1SD = DATEADD(DD,-13,@PayrollEndDate)
SET @W1ED = DATEADD(DD,-7,@PayrollEndDate)
SET @W2SD = DATEADD(DD,1,@W1ED)
SET @W2ED = @PayrollEndDate
--Get ALl the employees into EmployeeList table vairab;le
Declare @EmployeeList Table
(
EmpID int,
flag bit
)
Declare @EmployeeCount int
Declare @EmpID int
Declare @AgentTimeSheet_temp Table
(
[Date] Datetime,
[Airline Name] varchar(200),
[I/B #] varchar(200),
[O/B #] varchar(200),
[Position] varchar(200),
[Agent Name] varchar(200),
[Start Time] Time,
[End Time] Time,
[Total Time] Time,
[Notes] varchar(max),
flag int
)
Declare @AgentTimeSheet_Final Table
(
[Date] Datetime,
[Airline Name] varchar(200),
[I/B #] varchar(200),
[O/B #] varchar(200),
[Position] varchar(200),
[Agent Name] varchar(200),
[Start Time] Time,
[End Time] Time,
[Total Time] Time,
[Notes] varchar(max),
flag int
)
Declare @TotalTime Table
(
EmpId int,
Week1TotalTime int,
Week2TotalTime int,
AdjustedWeek1TotalTime int,
AdjustedWeek2TotalTime int
)
Insert into @EmployeeList(EmpID,flag)
Select e.Emp_id,0 from Employee e where e.StationId = @StationID and e.Status = 'Active'
SET @EmployeeCount= (Select COUNT(*) from @EmployeeList)
--Select @EmployeeCount
--Do Follwoing for each employee in the list
While (@EmployeeCount>0)
Begin
SET @EmpID = (Select top 1 EL.EmpID from @EmployeeList EL Where el.flag = 0)
Update @EmployeeList SET flag = 1 where EmpID = @EmpID
Print '@EmpID = '+cast(@EmpID as varchar)
Insert into @AgentTimeSheet_temp
Select convert(varchar,fr.Report_Date,101) [Date],ar.Airline_Name [Airline Name],
f.FlightCode [I/B #], f.OutBoundFlightNumber [O/B #], p.Position_Title [Position],EMP_NAME [Agent Name],
cast(convert(varchar(8),START_TIME,108)as Time)[Start Time],
cast(convert(varchar(8),END_TIME,108)as Time) [End Time],
case
when fpm.Is_fourHourBilling = 1 then
Case when ISNULL(dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0) < MinimumBillingHours then dbo.ConvertMintoTime(MinimumBillingHours)
Else
dbo.ConvertMintoTime(ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0))
End
else
dbo.ConvertMintoTime(ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0))
end
as [Total Time],
WRITE_UP [Notes],null
from dbo.Flight_Report_Info_Staffing a
Left join Flight_report fr on a.FLIGHT_REPORT_ID = fr.Flight_Report_ID
Left join Flight f on f.FlightId = fr.FlightID
Left Join Airline Ar on ar.AirlineID = f.AirlineId
Left Join Position p on p.PositionID = a.POSITION_ID
Left Join Flight_Position_Mapping FPM on FPM.FlightId = fr.FlightId and fpm.PositionID = a.POSITION_ID
where EMPID =@EmpID --and fr.Report_Date >= @W1SD and fr.Report_Date <= @W2ED and fr.Status = 'CLOSE'
and cast(convert(varchar,fr.Report_Date ,101)as datetime) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date ,101) as datetime) <=convert(varchar,@W2ED,101) and fr.Status = 'CLOSE'
--order by Report_Date
Union ALL
SElect
convert(varchar,fr.Report_Date,101) [Date],ar.Airline_Name [Airline Name],
f.FlightCode [Flight Code], f.OutBoundFlightNumber [O/B #], 'Additional Service' [Position]--p.Position_Title [Position]
,EMP_NAME [Agent Name],
cast(convert(varchar(8),frads.StartTime,108)as Time)[Start Time],
cast(convert(varchar(8),frads.EndTime,108)as Time) [End Time],
dbo.ConvertMintoTime(ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),frads.StartTime,108)as Time)
,cast(convert(varchar(8),frads.EndTime,108)as Time)),0))
as [Total Time],
ads.Notes [Notes],null
from
[Flight_report_AS_Agent_mapping] frads
Inner Join Employee e on frads.AgentID = e.Emp_id
inner join Flight_Report_Additional_service ads on frads.asid = ads.asid and frads.FRID = ads.FRID and ads.RqstSrvid = frads.RqstSrvid
Inner join Flight_Report fr on ads.FRID = fr.Flight_Report_ID
Left Join Flight f on f.FlightId = fr.FlightID
Left join Airline ar on f.AirlineId = ar.AirlineID
where frads.AgentID =@EmpID -- and fr.Report_Date >= @W1SD and fr.Report_Date <= @W2ED and fr.Status = 'CLOSE'
and cast(convert(varchar,fr.Report_Date ,101)as datetime) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date ,101) as datetime) <=convert(varchar,@W2ED,101) and fr.Status = 'CLOSE'
group by fr.Report_Date, ar.Airline_Name,f.FlightCode,f.OutBoundFlightNumber ,
e.EMP_NAME,frads.StartTime,frads.EndTime, ads.Notes
-- check overlapping records
Declare @RangeStartTime datetime
Declare @RangeEndTIme datetime
Declare @CurrentStartTime datetime
Declare @CurrentEndTime datetime
Declare @CurrentDate datetime
Declare @StartDate datetime
Declare @EndDate datetime
Declare @NextDayOverlappingFlag int
SET @NextDayOverlappingFlag= 0
Create table #ProcessedRecrds
(
id int identity(1,1),
Starttime datetime,
EndTime datetime
)
SET @StartDate = (Select min(date) from @AgentTimeSheet_temp where flag is null)
SET @EndDate = (Select MAX(date) from @AgentTimeSheet_temp where flag is null)
While(@StartDate<=@EndDate)
Begin
Print convert ( varchar,@startDate,101)
Declare @Count int
SET @Count = (Select COUNT(*) from @AgentTimeSheet_temp where Date = @StartDate and flag is null)
While (@Count > 0)
Begin
Print 'Count'+cast(@count as varchar)
Select Top 1 @CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)),--[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
--[End Time]
from @AgentTimeSheet_temp a where Date = @StartDate and flag is null
order by [Start Time]
Declare @DuplicateFlag int
SET @DuplicateFlag = 0
-- Fixing the duplicate records issue=> start time and end time same
Select @DuplicateFlag=T.Count from (
Select a.[Agent Name],a.Date,a.[Start Time],a.[End Time],COUNT(*) Count
from @AgentTimeSheet_temp a
where @CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) and
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
group by a.[Agent Name],a.Date,a.[Start Time],a.[End Time]
having COUNT(*)>1
)T
If(@DuplicateFlag >1)
Begin
WITH cte AS
(
Select ROW_NUMBER() OVER(PARTITION BY a.[Agent Name],a.Date,a.[Start Time],a.[End Time],a.Flag
ORDER BY a.[Agent Name],a.Date,a.[Start Time],a.[End Time],a.flag ) AS rno,
a.[Agent Name],a.Date,a.[Start Time],a.[End Time],a.flag
from @AgentTimeSheet_temp a
where @CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) and
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
)
UPDATE cte SET flag = 1
WHERE rno=2
End
If not exists (Select 1 from #ProcessedRecrds)
Begin
Insert into #ProcessedRecrds (Starttime,EndTime)
Select @CurrentStartTime,@CurrentEndTime
If(@NextDayOverlappingFlag = 1 and @CurrentStartTime<@RangeEndTIme)
Begin
Update @AgentTimeSheet_temp
SET flag = 1
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
SET @NextDayOverlappingFlag = 0
End
Else
Begin
Update @AgentTimeSheet_temp
SET flag = 0
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
End
SET @RangeStartTime = @CurrentStartTime
SET @RangeEndTIme = @CurrentEndTime
Print '1'
End
Else
Begin
--Declare @c int
--Select @c = MAX(id) from #ProcessedRecrds
--SET @c = ISNULL(@c,0)
--Select @RangeStartTime =Starttime, @RangeEndTIme = EndTime from #ProcessedRecrds where id = @c
--While(@c>0)
--Begin
--Print '@C='+convert(varchar,@c)
--Select @RangeStartTime =Starttime, @RangeEndTIme = EndTime from #ProcessedRecrds where id = @c
if(@CurrentStartTime=@RangeStartTime and @CurrentEndTime = @RangeEndTIme) --Changed
Begin
Update @AgentTimeSheet_temp
SET flag = 1
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
--SET @c = 0
Print '2'
--Select * from @AgentTimeSheet_temp
End
Else
Begin
if(@CurrentStartTime<@RangeStartTime and @CurrentEndTime <= @RangeStartTime)
Begin
Update @AgentTimeSheet_temp
SET flag = 0
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
Print '3'
SET @RangeStartTime = @CurrentStartTime
--Select * from @AgentTimeSheet_temp
End
Else
Begin
if(@CurrentStartTime>@RangeStartTime and @CurrentStartTime >= @RangeEndTime )
Begin
Update @AgentTimeSheet_temp
SET flag = 0
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
Print '4'
--If(@CurrentStartTime = @RangeEndTIme)
SET @RangeEndTIme = @CurrentEndTime
End
Else
Begin
if(@CurrentStartTime<=@RangeStartTime and @CurrentEndTime<@RangeEndTime and @CurrentEndTime > @RangeStartTime )
Begin
Update @AgentTimeSheet_temp
SET flag = 1
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
SET @RangeStartTime = @CurrentStartTime
--SET @c = 0
Print '5'
End
Else
Begin
if(@CurrentStartTime>@RangeStartTime and @CurrentStartTime < @RangeEndTime and @CurrentEndTime <= @RangeEndTime)
Begin
Update @AgentTimeSheet_temp
SET flag = 1
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
Print '6'
--SET @c = 0
End
Else
Begin
if(@CurrentStartTime>@RangeStartTime and @CurrentStartTime <@RangeEndTime and @CurrentEndTime > @RangeEndTime)
Begin
Update @AgentTimeSheet_temp
SET flag = 1
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
--SET @c = 0
SET @RangeEndTIme = @CurrentEndTime
Print '7'
End
Else
Begin
if(@CurrentStartTime<=@RangeStartTime and @CurrentEndTime > @RangeEndTime)
Begin
Update @AgentTimeSheet_temp
SET flag = 1
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
--SET @c = 0
SET @RangeEndTIme = @CurrentEndTime
SET @RangeStartTime = @CurrentStartTime
Print '8'
End
Else
Begin
Update @AgentTimeSheet_temp
SET flag = 0
--where @CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time] And Date = @StartDate and flag is null
where
--@CurrentStartTime= [Start Time] And @CurrentEndTime = [End Time]
@CurrentStartTime= (cast(Convert(varchar,@StartDate,101)+' '+convert(varchar(8),[Start Time],108)as Datetime)) AND --[Start Time],
@CurrentEndTime = dbo.ShiftOverlapCheck(convert(varchar(8),[Start Time],108),convert(varchar(8),[End Time],108),Convert(varchar,@StartDate,101))
And Date = @StartDate and flag is null
Print '10'
End
End
End
End
End
End
End
--SET @c = @c-1
--End
Insert into #ProcessedRecrds(Starttime,EndTime)
Select @CurrentStartTime,@CurrentEndTime
If(convert(varchar,@RangeEndTime,101) = CONVERT(varchar,@RangeStartTime+1,101))
SET @NextDayOverlappingFlag = 1
End
SET @Count = (Select COUNT(*) from @AgentTimeSheet_temp where Date = @StartDate and flag is null)
End
Truncate table #ProcessedRecrds
SET @StartDate = (Select min(date) from @AgentTimeSheet_temp where flag is null)
End
Insert into @AgentTimeSheet_Final
Select * from @AgentTimeSheet_temp
Delete from @AgentTimeSheet_temp
drop table #ProcessedRecrds
--Calcaute TotalTime and AdjustedTotalTime of Employee
Declare @Weekl1TotalTime int
Declare @Weekl2TotalTime int
Declare @AdjustedWeekl1TotalTime int
Declare @AdjustedWeekl2TotalTime int
Select @Weekl1TotalTime = isnull(sum(t.Week1TotalTime),0) ,
@Weekl2TotalTime = ISNULL( SUM(t.Week2TotalTime),0)
from(
Select Report_Date,
Case when convert(varchar,fr.Report_Date,101)>=convert(varchar,@W1SD,101) and convert(varchar,fr.Report_Date,101)<=convert(varchar,@W1ED,101) then
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)End as Week1TotalTime,
Case when convert(varchar,fr.Report_Date,101)>=convert(varchar,@W2SD,101) and convert(varchar,fr.Report_Date,101)<= Convert(varchar,@W2ED,101) then
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)End as Week2TotalTime
from dbo.Flight_Report_Info_Staffing a
Left join Flight_report fr on a.FLIGHT_REPORT_ID = fr.Flight_Report_ID
Left join Flight f on f.FlightId = fr.FlightID
where EMPID = @EmpID and cast(convert(varchar,fr.Report_Date,101) as datetime) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date,101) as datetime) <=convert(varchar,@W2ED,101)
and fr.Status = 'CLOSE'
Union ALL
Select Report_Date,
Case
when convert(varchar,fr.Report_Date,101)>=convert(varchar,@W1SD,101)
and convert(varchar,fr.Report_Date,101)<=convert(varchar,@W1ED,101) then
--ISNULL( ABS(DATEDIFF(mi,cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time))),0) End as Week1TotalTime,
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),frads.StartTime,108)as Time)
,cast(convert(varchar(8),frads.EndTime,108)as Time)),0)End as Week1TotalTime,
Case
when convert(varchar,fr.Report_Date,101)>=convert(varchar,@W2SD,101)
and convert(varchar,fr.Report_Date,101)<= Convert(varchar,@W2ED,101) then
--ISNULL( ABS(DATEDIFF(mi,cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time))),0) End as Week2TotalTime
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),frads.StartTime,108)as Time)
,cast(convert(varchar(8),frads.EndTime,108)as Time)),0)End as Week2TotalTime
from
[Flight_report_AS_Agent_mapping] frads
--Inner Join Employee e on frads.AgentID = e.Emp_id
inner join Flight_Report_Additional_service ads on frads.asid = ads.asid and frads.FRID = ads.FRID
Inner join Flight_Report fr on ads.FRID = fr.Flight_Report_ID
--Left Join Flight f on f.FlightId = fr.FlightID
--Left join Airline ar on f.AirlineId = ar.AirlineID
where frads.AgentID =@EmpID and cast(convert(varchar,fr.Report_Date ,101)as datetime) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date ,101) as datetime) <=convert(varchar,@W2ED,101)and fr.Status = 'CLOSE'
group by fr.Report_date, frads.StartTime, frads.EndTime
)
t
Select @AdjustedWeekl1TotalTime = isnull(sum(t2.AdjustedWeek1TotalTime),0),
@AdjustedWeekl2TotalTime = ISNULL( SUM(t2.AdjustedWeek2TotalTime),0)
from(
Select Report_Date,
Case when cast(convert(varchar,fr.Report_Date,101) AS datetime)>=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime) <=convert(varchar,@W1ED,101) then
case
when fpm.Is_fourHourBilling = 1 then
Case when ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0) < MinimumBillingHours then MinimumBillingHours
Else
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)
End
else
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)
end
end as AdjustedWeek1TotalTime,
Case when cast(convert(varchar,fr.Report_Date,101) AS datetime)>=convert(varchar,@W2SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime)<= Convert(varchar,@W2ED,101) then
case
when fpm.Is_fourHourBilling = 1 then
Case when ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0) < MinimumBillingHours then MinimumBillingHours
Else
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)
End
else
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),START_TIME,108)as Time),cast(convert(varchar(8),END_TIME,108)as Time)),0)
end
end as AdjustedWeek2TotalTime
from dbo.Flight_Report_Info_Staffing a
Left join Flight_report fr on a.FLIGHT_REPORT_ID = fr.Flight_Report_ID
Left join Flight f on f.FlightId = fr.FlightID
LEFT Join Flight_Position_Mapping fpm on fpm.FlightId = f.FlightId
and fpm.PositionID = a.POSITION_ID
where EMPID = @EmpID and cast(convert(varchar,fr.Report_Date,101) AS datetime) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime) <=convert(varchar,@W2ED,101)and fr.Status = 'CLOSE'
Union ALL
Select Report_Date,
Case when cast(convert(varchar,fr.Report_Date,101) AS datetime )>=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime )<=convert(varchar,@W1ED,101) then
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),frads.StartTime,108)as Time)
,cast(convert(varchar(8),frads.EndTime,108)as Time)),0)
end as AdjustedWeek1TotalTime,
Case when cast(convert(varchar,fr.Report_Date,101) AS datetime )>=convert(varchar,@W2SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime )<= Convert(varchar,@W2ED,101)
then
ISNULL( dbo.calculateTimeDiff(cast(convert(varchar(8),frads.StartTime,108)as Time)
,cast(convert(varchar(8),frads.EndTime,108)as Time)),0)
end as AdjustedWeek2TotalTime
from
[Flight_report_AS_Agent_mapping] frads
--Inner Join Employee e on frads.AgentID = e.Emp_id
inner join Flight_Report_Additional_service ads on frads.asid = ads.asid and frads.FRID = ads.FRID
Inner join Flight_Report fr on ads.FRID = fr.Flight_Report_ID
--Left Join Flight f on f.FlightId = fr.FlightID
--Left join Airline ar on f.AirlineId = ar.AirlineID
where frads.AgentID =@EmpID and cast(convert(varchar,fr.Report_Date,101) AS datetime ) >=convert(varchar,@W1SD,101)
and cast(convert(varchar,fr.Report_Date,101) AS datetime ) <=convert(varchar,@W2ED,101)and fr.Status = 'CLOSE'
group by fr.Report_Date, frads.StartTime,frads.EndTime
)
t2
Insert into @TotalTime(EmpId,Week1TotalTime,Week2TotalTime,AdjustedWeek1TotalTime,AdjustedWeek2TotalTime)
Select @EmpID,@Weekl1TotalTime,@Weekl2TotalTime,@AdjustedWeekl1TotalTime,@AdjustedWeekl2TotalTime
SET @EmployeeCount = @EmployeeCount-1
End
--Select @PayrollEndDate,@W1SD,@W1ED,@W2SD,@W2ED
--Overlapping ends here
Select * from @AgentTimeSheet_Final
order by [Agent Name],[Date],[Start Time],[Airline Name]
Select
dbo.ConvertMintoTime(sum(t.Week1TotalTime))as Week1TotalTime ,
dbo.ConvertMintoTime(sum(t.Week2TotalTime)) as Week2TotalTime --,
--dbo.ConvertMintoTime(sum(t.AdjustedWeek1TotalTime)) AdjustedWeek1TotalTime ,
--dbo.ConvertMintoTime(sum(t.AdjustedWeek2TotalTime)) AdjustedWeek2TotalTime
from @TotalTime t
Select
--dbo.ConvertMintoTime(sum(t.Week1TotalTime))as Week1TotalTime ,
--dbo.ConvertMintoTime(sum(t.Week2TotalTime)) as Week2TotalTime ,
dbo.ConvertMintoTime(sum(t.AdjustedWeek1TotalTime)) AdjustedWeek1TotalTime ,
dbo.ConvertMintoTime(sum(t.AdjustedWeek2TotalTime)) AdjustedWeek2TotalTime
from @TotalTime t
End
--Select *
--from dbo.Flight_Report_Info_Staffing a
--Left join Flight_report fr on a.FLIGHT_REPORT_ID = fr.Flight_Report_ID
--Left join Flight f on f.FlightId = fr.FlightID
--where EMPID = 24
Reply
Answers (
1
)
Primary Key with 3 field By Query
Find Min Time in Sql