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


Posted in PHP onOctober 09, 2006

//在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; 

PHP 相关文章推荐
JAVA/JSP学习系列之四
Oct 09 PHP
对javascript和select部件的结合运用
Oct 09 PHP
php代码把全角数字转为半角数字
Dec 10 PHP
PHP初学者常见问题集合 修正版(21问答)
Mar 23 PHP
PHP对接微信公众平台消息接口开发流程教程
Mar 25 PHP
php实现信用卡校验位算法THE LUHN MOD-10示例
May 07 PHP
解决CodeIgniter伪静态失效
Jun 09 PHP
php中函数前加&符号的作用分解
Jul 08 PHP
php自定义urlencode,urldecode函数实例
Mar 24 PHP
PHP register_shutdown_function()函数的使用示例
Jun 23 PHP
Discuz!X中SESSION机制实例详解
Sep 23 PHP
使用composer命令加载vendor中的第三方类库 的方法
Jul 09 PHP
PHP实现的功能是显示8条基色色带
Oct 09 #PHP
提升PHP执行速度全攻略(上)
Oct 09 #PHP
提升PHP执行速度全攻略(下)
Oct 09 #PHP
如何过滤高亮显示非法字符
Oct 09 #PHP
无限级别菜单的实现
Oct 09 #PHP
综合图片计数器
Oct 09 #PHP
php,不用COM,生成excel文件
Oct 09 #PHP
You might like
php 上一篇,下一篇文章实现代码与原理说明
2010/05/09 PHP
php中使用ExcelFileParser处理excel获得数据(可作批量导入到数据库使用)
2010/08/21 PHP
Symfony2之session与cookie用法小结
2016/03/18 PHP
用js正确判断用户名cookie是否存在的方法
2014/01/28 Javascript
Node.js插件的正确编写方式
2014/08/03 Javascript
jquery和css3实现的炫酷时尚的菜单导航
2014/09/01 Javascript
使用angular写一个hello world
2015/01/23 Javascript
javascript计时器详解
2015/02/28 Javascript
JavaScript使用cookie记录临时访客信息的方法
2015/04/07 Javascript
jqPlot jQuery绘图插件的使用
2016/06/18 Javascript
Angular 4.x中表单Reactive Forms详解
2017/04/25 Javascript
JS中的数组转变成JSON格式字符串的方法
2017/05/09 Javascript
jQuery实现锚点向下平滑滚动特效示例
2017/08/29 jQuery
node.js学习之断言assert的使用示例
2017/09/28 Javascript
JS运动改变单物体透明度的方法分析
2018/01/23 Javascript
Bootstrap 按钮样式与使用代码详解
2018/12/09 Javascript
vue或react项目生产环境去掉console.log的操作
2020/09/02 Javascript
[01:35]辉夜杯战队访谈宣传片—iG.V
2015/12/25 DOTA
精确查找PHP WEBSHELL木马的方法(1)
2011/04/12 Python
python3实现的zip格式压缩文件夹操作示例
2019/08/17 Python
python圣诞树编写实例详解
2020/02/13 Python
部署Django到阿里云服务器教程示例
2020/06/03 Python
基于Python爬取股票数据过程详解
2020/10/21 Python
python基于exchange函数发送邮件过程详解
2020/11/06 Python
CSS3 实现的火焰动画
2020/12/07 HTML / CSS
利用简洁的图片预加载组件提升html5移动页面的用户体验
2016/03/11 HTML / CSS
求职信范文英文版
2014/01/05 职场文书
应届毕业生个人求职自荐信
2014/01/06 职场文书
仓库组长岗位职责
2014/01/29 职场文书
历史专业学生的自我评价
2014/02/28 职场文书
外语系毕业生求职自荐信
2014/04/12 职场文书
《金色的脚印》教后反思
2014/04/23 职场文书
企业趣味活动方案
2014/08/21 职场文书
教师党的群众路线学习心得体会
2014/11/04 职场文书
2015年党员公开承诺书范文
2015/01/22 职场文书
Go Gin实现文件上传下载的示例代码
2021/04/02 Golang