加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 电商 > 正文

如何模拟SQL Server的两个日期处理函数

发布时间:2018-09-10 10:46:01 所属栏目:电商 来源:站长网
导读://在PHP中处理赏罚日期很是不利便,好比求两个日期之间相差的月份?该怎么办呢? //文件名:date.inc.php3 //在行使这两个函数前,要先将日期或日期时刻转换成timestamp范例。 //如: //$today=mktime(0,0,0,date("m"),date("d"),date("Y")); /****模仿sqlserve
//在PHP中处理赏罚日期很是不利便,好比求两个日期之间相差的月份?该怎么办呢? 
//文件名:date.inc.php3 
//在行使这两个函数前,要先将日期或日期时刻转换成timestamp范例。 
//如: 
//$today=mktime(0,0,0,date("m"),date("d"),date("Y")); 

/****模仿sqlserver中的dateadd函数******* 
$part 范例:string 
取值范畴:year,month,day,hour,min,sec 
暗示:要增进的日期的哪个部门 
$n 范例:数值 
暗示:要增进几多,按照$part抉择增进哪个部门 
可为负数 
$datetime范例:timestamp 
暗示:增进的基数 
返回 范例:timestamp 
**************竣事**************/ 
function dateadd($part,$n,$datetime){ 
$year=date("Y",$datetime); 
$month=date("m",$datetime); 
$day=date("d",$datetime); 
$hour=date("H",$datetime); 
$min=date("i",$datetime); 
$sec=date("s",$datetime); 
$part=strtolower($part); 
$ret=0; 
switch ($part) { 
case "year": 
$year+=$n; 
break; 
case "month": 
$month+=$n; 
break; 
case "day": 
$day+=$n; 
break; 
case "hour": 
$hour+=$n; 
break; 
case "min": 
$min+=$n; 
break; 
case "sec": 
$sec+=$n; 
break; 
default: 
return $ret; 
break; 
} 
$ret=mktime($hour,$min,$sec,$month,$day,$year); 
return $ret; 
} 

/****模仿sqlserver中的datediff函数******* 
$part 范例:string 
取值范畴:year,month,day,hour,min,sec 
暗示:要增进的日期的哪个部门 
$date1,$date2 范例:timestamp 
暗示:要较量的两个日期 
返回 范例:数值 
**************竣事*(*************/ 
function datediff($part,$date1,$date2){ 
//$diff=$date2-$date1; 
$year1=date("Y",$date1); 
$year2=date("Y",$date2); 
$month2=date("m",$date2); 
$month1=date("m",$date1); 
$day2=date("d",$date2); 
$day1=date("d",$date1); 
$hour2=date("d",$date2); 
$hour1=date("d",$date1); 
$min2=date("i",$date2); 
$min1=date("i",$date1); 
$sec2=date("s",$date2); 
$sec1=date("s",$date1); 

$part=strtolower($part); 
$ret=0; 
switch ($part) { 
case "year": 
$ret=$year2-$year1; 
break; 
case "month": 
$ret=($year2-$year1)*12+$month2-$month1; 
break; 
case "day": 
$ret=(mktime(0,0,0,$month2,$day2,$year2)-mktime(0,0,0,$month1,$day1,$year1))/(3600*24); 
break; 
case "hour": 
$ret=(mktime($hour2,0,0,$month2,$day2,$year2)-mktime($hour1,0,0,$month1,$day1,$year1))/3600; 
break; 
case "min": 
$ret=(mktime($hour2,$min2,0,$month2,$day2,$year2)-mktime($hour1,$min1,0,$month1,$day1,$year1))/60; 
break; 
case "sec": 
$ret=$date2-$date1; 
break; 
default: 
return $ret; 
break; 
} 
return $ret; 
} 

}

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读