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

papa8899

papa8899

2016-01-29 13:35

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

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

 

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

主要的论点是集中在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 |
+---------------------------+

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

啊?不会吧?这样也不行啊?
我接着试命令
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://m.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函数实现的效率高


展开更多 50%)
分享

猜你喜欢

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

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

经期前后三天内不要游泳

育儿知识 怀孕 孕妇
经期前后三天内不要游泳

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

女人经期前后四天内不能游泳

经期 女人 游泳 女性健康
女人经期前后四天内不能游泳

如何在一天内正确的安排减肥

减肥 瘦身 减脂
如何在一天内正确的安排减肥

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

怀孕头28天内吃药 不必担心胎儿畸形

胎儿畸形 叶酸
怀孕头28天内吃药 不必担心胎儿畸形

经期后七天内吃它滋补又养颜

女人养生
经期后七天内吃它滋补又养颜

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

PSPFF5篇《最终幻想-纷争》流程详细攻略

PSPFF5篇《最终幻想-纷争》流程详细攻略

PHP下对缓冲区的控制

PHP下对缓冲区的控制
下拉加载更多内容 ↓