zoukankan      html  css  js  c++  java
  • sql 通过某段时间求得改段时间内的工作时长,排除工作日

    CREATE FUNCTION Fun_GetTotalHourBySomeTime(@TaskId NVARCHAR(30),@Bu_trupstartDate NVARCHAR(50),@Bu_trupEndDate NVARCHAR(50))

    RETURNS FLOAT
    AS
    BEGIN
    --计算工作日的天数
    DECLARE @tStartDate DATE
    DECLARE @tEndDate DATE
    SET @tStartDate=CONVERT(NVARCHAR(50),@Bu_trupstartDate,112)
    SET @tEndDate=CONVERT(NVARCHAR(50),@Bu_trupEndDate,112)

    DECLARE @DAYNum DATE ,
    @COUNT INT;
    SET @DAYNum = @tStartDate;
    SET @COUNT = 0;
    WHILE @DAYNum <= @tEndDate
    BEGIN
    SET @COUNT = @COUNT + ( CASE DATEPART(WEEKDAY, @DAYNum)
    WHEN 1 THEN 0
    WHEN 7 THEN 0
    ELSE 1
    END );
    SET @DAYNum = DATEADD(DAY, 1, @DAYNum);
    END
    --工作日的天数先少计算一天;
    SET @COUNT=@COUNT-1;

    DECLARE @sResultHour FLOAT
    DECLARE @Day INT
    DECLARE @startTimeH INT
    DECLARE @endTimeH INT
    DECLARE @startTimeM INT
    DECLARE @endTimeM INT
    --SELECT @sResultHour=8
    SELECT @Day=DATEDIFF(DAY,Bu_trupstartDate,Bu_trupEndDate),@startTimeH=startTimeH,@startTimeM=startTimeM,@endTimeH=endTimeH,@endTimeM=endTimeM
    FROM dbo.VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    IF(@Day=0)
    BEGIN
    IF(@startTimeH<12 AND @endTimeH<=12)
    BEGIN
    SELECT @sResultHour=CAST(DATEDIFF(MINUTE,Bu_trupstartDate,Bu_trupEndDate)*1./60 AS DECIMAL(18,1)) FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    IF(@startTimeH<12 AND @endTimeH>12)
    BEGIN
    SELECT @sResultHour=(DATEDIFF(HOUR,Bu_trupstartDate,Bu_trupEndDate))-1 FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    IF(@startTimeH>=12)
    BEGIN
    SELECT @sResultHour=CAST(DATEDIFF(MINUTE,Bu_trupstartDate,Bu_trupEndDate)*1./60 AS DECIMAL(18,1)) FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    END
    IF(@Day>=1)
    BEGIN
    IF(@startTimeH<12 AND @endTimeH<=12)
    BEGIN
    SELECT @sResultHour=CAST((@COUNT*7.5*60+(@endTimeH-@startTimeH)*60+(@endTimeM-@startTimeM))*1./60 AS DECIMAL(18,1))
    FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    IF(@startTimeH<12 AND @endTimeH>12)
    BEGIN
    SELECT @sResultHour=CAST((@COUNT*7.5*60+(@endTimeH-@startTimeH-1)*60+(@endTimeM-@startTimeM))*1./60 AS DECIMAL(18,1))
    FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    IF(@startTimeH>=12)
    BEGIN
    SELECT @sResultHour=CAST((@COUNT*7.5*60+(@endTimeH-@startTimeH)*60+(@endTimeM-@startTimeM))*1./60 AS DECIMAL(18,1))
    FROM VIEW_Apply_Bu_tripReport WHERE taskId=@TaskId
    END
    END
    RETURN @sResultHour
    END

    如有更好的解决思路,还请分享学习,谢谢!!!

  • 相关阅读:
    BZOJ3992 [SDOI2015]序列统计
    BZOJ3991 [SDOI2015]寻宝游戏
    BZOJ4007 [JLOI2015]战争调度
    BZOJ4006 [JLOI2015]管道连接
    BZOJ4004 [JLOI2015]装备购买
    P2567 [SCOI2010]幸运数字
    P1447 [NOI2010]能量采集
    比赛-Round 2 (11 Jul)
    题解-弹飞绵羊 (HNOI2015)
    归并排序模板
  • 原文地址:https://www.cnblogs.com/yachao1120/p/7594296.html
Copyright © 2011-2022 走看看