快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

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

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

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

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

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

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

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

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

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

mysql>select 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)
);


这里的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函数实现的效率高
返回类别: 教程
上一教程: 分页SQL SERVER存储过程
下一教程: 更改数据库中表的所属用户的两个方式

您可以阅读与"如何实现日期比较,暨实现显示5天内,显示10天内的记录"相关的教程:
· MYSQL中如何实现TOP N及M至N段的记录查询?
· 如何在SQL数据库中得到重复次数最多的记录
· 如何实现MYSQL中的用户治理
· MS SQL SERVER中如何迅速获取表的记录总数
· 如何用sql语句修改数据表中字段,实现identity(100,1)
    微笑服务 优质保证 索取样品