>백엔드 개발 >PHP 튜토리얼 >sqlserver2000 Personal Edition은 SQLSERVER의 두 가지 기능인 dateadd, datediff를 시뮬레이션합니다.

sqlserver2000 Personal Edition은 SQLSERVER의 두 가지 기능인 dateadd, datediff를 시뮬레이션합니다.

WBOY
WBOY원래의
2016-07-29 08:34:03954검색

//파일명: date.inc.php3
//이 두 함수를 사용하기 전에 먼저 날짜 또는 날짜 시간을 타임스탬프 유형으로 변환해야 합니다.
//예:
//$today=mktime(0,0,0,date("m"),date("d"),date("Y"));
/ * ***sqlserver에서 dateadd 함수 시뮬레이션************
$part 유형: 문자열
값 범위: 연, 월, 일, 시, 분, 초
는 다음을 의미합니다. 추가할 날짜
$n 유형: 숫자 값
의 의미: 얼마나 늘릴지, 어느 부분을 늘릴지는 $part에 따라 결정됩니다.
음수일 수 있습니다.
$datetime 유형: 타임스탬프
의미: 증가 기준
반환 유형: 타임스탬프
****************끝************ *********/
함수 dateadd($part,$n,$datetime){
$year=date("Y",$datetime);
$m>$day=date( " d",$datetime);
$hour=date("H",$datetime);
$min=date("i",$datetime);
$sec=date("s " ,$datetime);
$part=strtolower($part);
$ret=0;
스위치($part) {
case "연도":
$year =$ n ;
break;
case "월":
$month =$n;
break;
case "day":
$day =$n;
break ;
case "시간":
$hour =$n;
break;
case "min":
$min =$n;
break;
case " 초 ":
$sec =$n;
break;
기본값:
return $ret;
break;
}
$ret=mktime($hour,$ min ,$sec,$month,$day,$year);
return $ret;
}
/****sqlserver에서 datediff 함수 시뮬레이션************
$part 유형: 문자열
값 범위: 연도, 월, 일, 시, 분, 초
는 다음을 의미합니다. 추가할 날짜
$date1,$date2의 어느 부분 유형: 타임스탬프
표시: 비교할 두 날짜
반환 유형: 숫자 값
************ ****끝 *(*************/
function datediff($part,$date1,$ 날짜2 ){
//$diff=$date2-$date1;
$year1=date("Y",$date1);
$year2=date("Y",$date2);
$m>$m>$day2=날짜("d",$date2);
$day1=날짜("d",$date1);
$hour2=날짜("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;
스위치($part) {
케이스 "연도":
$ret=$year2-$year1;
break;
케이스 "월":
$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;
기본값:
return $ret;
break;
}
$ret;
}
?>
위 내용은 SQLSERVER를 시뮬레이션하는 sqlserver2000 Personal Edition의 두 가지 기능인 dateadd와 datediff를 소개하며, sqlserver2000 Personal Edition의 내용도 포함되어 있어 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.