由于项目当中有用到这样的一个方法,故在这边做记录
- function GetMonth($sign="1")
- {
- //得到系统的年月
- $tmp_date=date("Ym");
- //切割出年份
- $tmp_year=substr($tmp_date,0,4);
- //切割出月份
- $tmp_mon =substr($tmp_date,4,2);
- $tmp_nextmonth=mktime(0,0,0,$tmp_mon+1,1,$tmp_year);
- $tmp_forwardmonth=mktime(0,0,0,$tmp_mon-1,1,$tmp_year);
- if($sign==0){
- //得到当前月的下一个月
- return $fm_next_month=date("Ym",$tmp_nextmonth);
- }else{
- //得到当前月的上一个月
- return $fm_forward_month=date("Ym",$tmp_forwardmonth);
- }
- }
另外在做时间的需要注意:
如果以日期作为结束时,转换成时间戳会导致时间有差异的 比如我使用日期是20160821,不计算后面的时间,但系统实际会计算一个时间,即:20160821 00:00:00 为了符合到租日期,转换成时间戳的时候默认就要加上,20160821 23:59:59获取当前月份的第一天和最后一天:
查询一个月,一个时间段的数据 获取本月的第一天和最后一天 $firstday = date('Y-m-d', mktime(0, 0, 0, date('m'), 1)); $lastday = date('Y-m-d', mktime(0, 0, 0,date('m')+1,1)-1);function GetFristAndLastDay(){
$firstday = date('Y-m-d 0:0:0', mktime(0, 0, 0, date('m'), 1));
$lastday = date('Y-m-d 23:59:59', mktime(0, 0, 0,date('m')+1,1)-1);
$date = array();
$date['start'] = strtotime($firstday);
$date['end'] = strtotime($lastday);
return $date;
}