私たちの日常業務では、業務量を考慮して時間によるデータベースの水平分割を使用することが多く、分割後のクエリでは時間の問題が発生することがよくあります。たとえば、現在時刻から 1 か月後のユーザーの注文ステータスをクエリしたいとします。このとき、strtotime() 関数を使用して処理します。
ただし、strtotime()を使用する場合は十分に注意する必要があります。まずコードを見てみましょう。このコードの目的は、たとえば、今日は 2014 年 8 月 1 日です。2 か月前の年と月を取得したいと考えています。 array("0"=>"201406", "1"=>"201407",)
リーリー
表面的にはコードに問題がないように見えますが、テストを行ってみましょう。テストの目的は非常に単純です。毎月の日
リーリーテスト結果を見てみましょう。テスト結果から、各月の日数が異なるを無視していることがわかり、strtotime() は異なる結果をもたらします
。
では、strtotime("-$n month") はどのように計算されるのでしょうか?次のようにテストを実行します: 結果を確認します
リーリー
(注: strtotime("-$n month")、2番目のパラメータは省略されています、2番目のパラメータは距離時間を示し、省略された場合は現在時刻を示します)
時間 |
違い |
理論の時間 |
結果 |
7月31日 |
1ヶ月前 |
6月31日 |
6月は30日しかないので、7月1日に1日追加します |
7月31日 |
2ヶ月前 |
5月31日 |
|
7月31日 |
3ヶ月前 |
4月31日 |
4月は30日しかないので、5月1日に1日追加します |
…… |
この場合、strtotime("-$n month") を使用してニーズを処理するにはどうすればよいでしょうか?
参考までに手書きのコードを以下に示します
リーリーmktime() にはパラメータが必要です。
2 日後を取得する最も簡単な方法は次のとおりです:
echo date("Y-m-d",strtotime("+2 days"));
echo '
';
echo date ("Y-m-d H:i:s",strtotime("+2 days"));
?>
strtotime の関数の説明をよく見てください。
+10 時間
-2 時間
なども可能ですの上。
$date = date("Y-m-d", strtotime('2012-01-20') + 60*60*24);