当前位置: 首页 > 图文教程 > 网络编程 > PHP > 如何实现日期比较,暨实现显示5天内,显示10天内的记录

PHP
PHP 开发环境的选择、建立及使用(5)
PHP 开发环境的选择、建立及使用(6)
PHP 开发环境的选择、建立及使用(7)
PHP 开发环境的选择、建立及使用(8)
PHP 开发环境的选择、建立及使用(9)
Win2003下APACHE PHP5 MYSQL4 PHPMYADMIN 的简易安装配置
PHP新手上路(八) 文件上传
PHP新手上路(九) 投票系统
PHP新手上路(十) 简易banner动态更替
PHP新手上路(十一) 数据库链接
PHP新手上路(十二)使用PHP来操作Oracle数据库
PHP新手上路(十三)PHP资源
PHP新手上路(十四) 其他杂项
session全教程(一)
session全教程(二)
session全教程(三)
PHP编码规范
第十五节--Zend引擎的发展 -- Classes and Objects in PHP5 [15]
第十四节--命名空间 -- Classes and Objects in PHP5 [14]
第十二节--类的自动加载 -- Classes and Objects in PHP5 [12]

PHP 中的 如何实现日期比较,暨实现显示5天内,显示10天内的记录


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 100 ::
收藏到网摘: n/a

前几天发了一张帖子,就是关于显示5天内这种日期比较,

http://www.oso.com.cn/forum/read.php?theme_id=7459

主要的论点是集中在SELECTsomethingFROMtable
WHERETO_DAYS(NOW())-TO_DAYS(date_col)<=5;上,我试验了半天,结果还是出错,今天看了MYSQL的函数,终于出来了结果,不敢独享,贴出来供大家研究,(虽然技术含量不高,别扔我柿子就行,呵呵)

MYSQL的TO_DAYS(DATE)函数是这样说明的:
传回DATE到公元0年的总日数,我测试了一下
mysql>selectto_days(now(0));
+--------------------------+
|TO_DAYS(NOW())|
+--------------------------+
|730839|
+--------------------------+

出来的是当前时间距离公元0年的总日数,接着我试着用上面的语句测试;

mysql>selectTO_DAYS(NOW())-TO_DAYS(date_col)<=5;
出现结果:
ERROR1054:Unknowncolumn'date_col'in'fieldfirst'

此路不通了,我就试着直接把5代到date_col里去

mysql>selectto_days(now())-to_days(5);
出现结果:
+---------------------------+
|to_days(now())-to_days(5)|
+---------------------------+
|NULL|
+---------------------------+

啊?不会吧?这样也不行啊?
我接着试命令
mysql>select。。。。

突然猛的想到,嘿嘿,to_days(now())出来的是整数,我直接跟整数运算就行了,何必再to_days(date)呢?马上试验

mysql>selectto_days(now())-5;
+--------------------------+
|to_days(now())-5|
+--------------------------+
|730834|
+--------------------------+


OK,万岁,终于得到了我想要的结果,呵呵下面就是在PHP代码中用SELECT查询了

我存数据库向来的习惯就是DATEANDTIME用NOW()直接赋值,显示的时候不用格式化,直接取出来就能用,

下面是我的一个库的部分结构
CREATETABLEinfomess(
infoidint(11)NOTNULLauto_increment,
topicvarchar(255)NOTNULL,
……
emailvarchar(50),
dateandtimedatetimeDEFAULT'0000-00-0000:00:00'NOTNULL,
PRIMARYKEY(infoid)
);


这里的DATEANDTIME是标准的日期格式,然后我要查询5天内的记录,下面是SQL查询语句
$sql="select*frominfomesswhereto_days(dateandtime)>=(to_days(now())-5)orderbyinfoiddesclimit$offset,$psize";

就要一个whereto_days(dateandtime)>=(to_days(now())-5)就够了后面的是另外的,这里的5可以设为一个变量

whereto_days(dateandtime)>=(to_days(now())-$limitdays)

然后$limitdays可以用GET方式传递(多数是有GET方式传递)

在你的PHP后面跟上?limitdays=5就行了显示10天内也一样,$limitdasy改成10就行了

以上是利用MYSQL函数得到这样的结果,以上的结果都经过测试,因为时间匆忙,如果代码有什么问题,请跟帖提出,谢谢


还有朋友说利用UNIX戳记来得到这样的结果,请问哪位写过这样的代码,贴点出来,供大家参考比较,也可以测试判断一下PHP函数还是MYSQL函数实现的效率高