新聞中心
SQL中怎么計算工作日,針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),鎮(zhèn)寧企業(yè)網(wǎng)站建設(shè),鎮(zhèn)寧品牌網(wǎng)站建設(shè),網(wǎng)站定制,鎮(zhèn)寧網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,鎮(zhèn)寧網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
CREATE FUNCTION Time_Span_of_minutes(
start_day DATETIME,
end_day DATETIME)
RETURNS FLOAT
BEGIN
-- 返回按分鐘計算兩段時間的間隔,采用逐日靠近的方法求解,一天按8小時480分鐘計算,周末不計,不考慮法定節(jié)假日。
-- 如果起始日期在周末,則計算當(dāng)天時間。
DECLARE minutes FLOAT;
DECLARE next_day DATETIME;
SET minutes=0.0;
SET next_day=start_day;
IF(TIMESTAMPDIFF(DAY,start_day,end_day)<1.0) THEN
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,start_day,end_day);
ELSE
WHILE TIMESTAMPDIFF(DAY,next_day,end_day)>=1.0 DO
IF ((DAYOFWEEK(next_day)=7) OR (DAYOFWEEK(next_day)=1)) THEN
SET next_day=next_day+INTERVAL 1 DAY;
ELSE
SET next_day=next_day+INTERVAL 1 DAY;
SET minutes=minutes+480.0;
END IF;
END WHILE;
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,next_day,end_day);
IF ((DAYOFWEEK(start_day)=7) OR (DAYOFWEEK(start_day)=1)) THEN
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,start_day,CONVERT(CONCAT(SUBSTRING(start_day FROM 1 FOR 10),' 17:30:00'),DATETIME));
END IF;
END IF;
RETURN minutes;
END;
CREATE FUNCTION Time_Span_of_minutes(
start_day DATETIME,
end_day DATETIME)
RETURNS FLOAT
BEGIN
-- 返回按分鐘計算兩段時間的間隔,采用逐日靠近的方法求解,一天按8小時480分鐘計算,周末不計,不考慮法定節(jié)假日。
-- 如果起始日期在周末,則計算當(dāng)天時間。
DECLARE minutes FLOAT;
DECLARE next_day DATETIME;
SET minutes=0.0;
SET next_day=start_day;
IF(TIMESTAMPDIFF(DAY,start_day,end_day)<1.0) THEN
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,start_day,end_day);
ELSE
WHILE TIMESTAMPDIFF(DAY,next_day,end_day)>=1.0 DO
IF ((DAYOFWEEK(next_day)=7) OR (DAYOFWEEK(next_day)=1)) THEN
SET next_day=next_day+INTERVAL 1 DAY;
ELSE
SET next_day=next_day+INTERVAL 1 DAY;
SET minutes=minutes+480.0;
END IF;
END WHILE;
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,next_day,end_day);
IF ((DAYOFWEEK(start_day)=7) OR (DAYOFWEEK(start_day)=1)) THEN
SET minutes=minutes+TIMESTAMPDIFF(MINUTE,start_day,CONVERT(CONCAT(SUBSTRING(start_day FROM 1 FOR 10),' 17:30:00'),DATETIME));
END IF;
END IF;
RETURN minutes;
END;
關(guān)于SQL中怎么計算工作日問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。
本文題目:SQL中怎么計算工作日
瀏覽路徑:http://fisionsoft.com.cn/article/ighcds.html