PHP 獲取兩個時間之間的月份


## 獲取兩個時間之間的間距時間

$s = '2017-02-05';
$e = '2017-07-20';

 

$start    = new \DateTime($s);
$end      = new \DateTime($e);
// 時間間距 這里設置的是一個月
$interval = \DateInterval::createFromDateString('1 month');
$period   = new \DatePeriod($start, $interval, $end);
foreach ($period as $dt) {
    echo $dt->format("Y-m") . "<br>\n";
}

輸出結果:

2017-03
2017-04
2017-05
2017-06

 

獲取頭部和尾部的時間范圍:

有時候會遇到這樣一個場景如:

存在兩行表:

  1. 月度考情表(記錄每個員工一個月的考勤)

  2. 日度考勤表(記錄每個員工每一天的考勤)

 

這時候有一個需求是這樣的:

查詢 “2017-02-05” —— “2017-012-20”

這之間的員工的考勤數據。

一般情況下會這么做,直接 根據時間篩選日度考勤表。結果是沒問題的,但是試想一下,如果有2000個員工,每天的考勤, 那一年是不是  73W的數據了,如果兩年呢? 加上做一些其他的操作,是不是效率很慢?

這個時候可以查詢 “2017-02-05” —— “2017-012-20” 兩個日期時間的完整月份也就是 2017-03,2017-04,2017-05..以此類推

剩下的不完整日期再拿出來 篩選日度考勤表,那么篩選的量會大大降低。

以下是獲取不完整日期的代碼:

$s = '2017-02-05';
$e = '2017-07-20';

// 獲取頭部的時間范圍
if (date('j', strtotime($s)) > 1) {
    $start_day_head = date('Y-m-01', strtotime($s));
    $end_day_head = date('Y-m-t', strtotime($s));
    $s = date('Y-m-01', strtotime("+1 months", strtotime($s)));
}

// 獲取尾部的時間范圍
if (date('j', strtotime($e)) > 1) {
    $start_day_tail = date('Y-m-01', strtotime($e));
    $end_day_tail = date('Y-m-t', strtotime($e));
    $e = date('Y-m-t', strtotime("-1 months", strtotime($e)));
}

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM