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

2016-01-29 13:35 14 1 收藏

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

【 tulaoshi.com - PHP 】

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

 

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)

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

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

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

mysqlselect TO_DAYS(NOW()) - TO_DAYS(date_col) <= 5;
出现结果:
ERROR 1054:Unknown column 'date_col' in 'field first'

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

mysqlselect to_days(now()) - to_days(5);
出现结果:
+---------------------------+
|to_days(now()) - to_days(5)|
+---------------------------+
| NULL |
+---------------------------+

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

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

mysqlselect to_days(now()) - 5;
+--------------------------+
| to_days(now()) -5 |
+--------------------------+
| 730834 |
+--------------------------+


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

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

下面是我的一个库的部分结构
CREATE TABLE infomess (
infoid int(11) NOT NULL auto_increment,
topic varchar(255) NOT NULL,

email varchar(50),
dateandtime datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
PRIMARY KEY (infoid)
);

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/php/)


这里的DATEANDTIME是标准的日期格式,然后我要查询5天内的记录,下面是SQL查询语句
$sql="select * from infomess where to_days(dateandtime) = (to_days(now()) - 5) order by infoid desc limit $offset,$psize";

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

where to_days(dateandtime) = (to_days(now()) - $limitdays)

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

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

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


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


来源:https://www.tulaoshi.com/n/20160129/1490727.html

延伸阅读
标签: 手表 腕表 天梭
天梭手表多少天内包换 我们买了一个东西后害怕的就是没多久就不小心弄坏了,又或者是本来就是坏的,这个时候我们就会想着包换这个方面了,那么这个天梭手表多少天内是可以包换的呢,就让我们下面一起来看看吧,这样也心里好有一个数。 手表有别于其他商品,通常一旦售出,是概不退换的;仅给予保修,保修范围仅限机芯(所有外观的零部件是一...
标签: 新生儿
俄罗斯新生儿检查视频网络疯传 新生儿该做哪些检查 俄罗斯新生儿检查视频网络疯传 这几天微博有一条视屏被疯狂转发,据说是俄罗斯新生儿检查。视频中,一个穿着五大三粗的男子对一个貌似新生儿的小小婴儿做个各种貌似检查实则蹂躏的粗鲁冬至,小婴儿一直发出凄惨的哭声。看到这个视频,网友们纷纷调侃:”你确定这不...
页面代码如下:
标签: ASP
      我们知道:对于一个留言簿,如果我们只让上网者能看到自己的留言而看不到其他人的留言,那么这类留言簿也就只能适用于某些特殊的地方(例如“客户意见返馈表”或“投诉留言”之类的留言,因为假如你是老板的话,你也不会愿意将自己的“伤疤”随便揭开给人看)。因此我们必须令每一位上网者都能看到留言簿中的所...
标签: ASP
  大家都知道在Dreamwerver中可以很方便地实现记录集的分页显示,但是生成的代码的确很庞大,影响了网页的显示速度,看起来条理也不是很清晰,那么,可不可以用简单的方式实现同样的功能呢?当然可以,笔者通过以下一些简单的代码就实现了记录集的分页显示,现在拿出来大家一起分享。 主要代码如下: <% If rs1.recordcount...